当前位置: 首页 > news >正文

Apache Shenyu 本地启动及快速入门

Apache Shenyu 本地启动及快速入门

1. 环境准备

本文中使用 MySQL 来作为 ShenYu 数据库,使用 Docker Compose 部署 MySQL。

或者使用本地 MySQL 数据库也可,使用本地数据库时跳转到 1.3 配置数据库表。

1.1 docker-compose.yml

services:db:image: mysqlcontainer_name: mysqlrestart: alwayscommand: --default-authentication-plugin=caching_sha2_password --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --explicit_defaults_for_timestamp=true --lower_case_table_names=1 --max_allowed_packet=128M;ports:- 3306:3306volumes:- ./data:/var/lib/mysql- ./my.cnf:/etc/my.cnf:ro- ./log:/var/log/mysql- ./initdb.d:/docker-entrypoint-initdb.denvironment:MYSQL_ROOT_PASSWORD: toor

1.2 MySQL 数据库配置

[mysqld]skip-host-cache
skip-name-resolve
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
secure-file-priv=/var/lib/mysql-files
user=mysqlpid-file=/var/run/mysqld/mysqld.pidtmpdir=/tmp

1.3 SQL 文件配置:

SQL 数据文件下载地址:https://github.com/apache/shenyu/blob/master/db/init/mysql/schema.sql

将数据文件在同级目录的 init.d 目录下并改为 init.sql.

Tips: 或者不自动执行 sql 脚本,启动之后手动执行 sql 文件。

2. 工具和代码下载

本文中使用 IDEA,从 Github clone 仓库并使用 IDEA 打开。

Github:https://github.com/apache/shenyu

3. 编译及启动

3.1 安装编译

执行如下命令将 shenyu 安装到本地的 mvn 仓库,后面启动 example 时需要用到。

mvn clean install '-Dmaven.javadoc.skip=true' '-B' '-Drat.skip=true' '-Djacoco.skip=true' '-DskipITs' '-DskipTests'

3.2 配置修改

  1. 将 shenyu-admin/src/resouce/application.yml#24 中的激活配置从 h2 改为 mysql
  2. 将 shenyu-admin/src/resouce/application-mysql.yml#25 中的 MySQL 密码改为 1.1 中的 toor 或者你自己的数据库密码。

3.3 启动

  1. 启动 Admin 管理端(作为网关控制面) org.apache.shenyu.admin.ShenyuAdminBootstrap
  2. 启动 ShenYu 网关(作为网关数据面)org.apache.shenyu.bootstrap.ShenyuBootstrapApplication

3.4 访问 Admin 页面

浏览器访问 http://127.0.0.1:9095,默认的用户名密码为:admin/123456。

如果一切顺利,你将会看到 shenyu 网关的 Admin 页面。

4. Example 测试

接下来使用 shenyu-examples/shenyu-examples-http 作为测试服务,使用 IDEA 单独打开或者为其设置工作目录。

Tips: 务必完成 3.1 的编译动作!

完成 example 启动之后,观察各个服务控制台,会看到日志输出。

然后在 Admin 控制台可以看到已经注册的的 http 路由:

启动之前:
在这里插入图片描述

启动之后:

在这里插入图片描述

5. 流量处理

首先需要明确下面一些细节问题:

  1. Shenyu 网关流量通过插件和选择器以及路由规则来控制;
  2. 网关流量入口在:org.apache.shenyu.web.handler.ShenyuWebHandler.DefaultShenyuPluginChain#execute
  3. 插件执行链路在,完成路由规则的筛选并交由插件实现执行:org.apache.shenyu.plugin.base.AbstractShenyuPlugin#execute

通过断点即可看到执行的插件链以及插件数据信息等

参考文档

  1. https://shenyu.apache.org/zh/docs/deployment/deployment-before
  2. https://shenyu.apache.org/zh/docs/deployment/deployment-local
  3. https://shenyu.apache.org/zh/blog/Plugin-SourceCode-Analysis-Divide-Plugin/
  4. https://github.com/deigmata-paideias/deigmata-paideias/blob/main/docker-compose-tmpl/mysql
http://www.dtcms.com/a/312676.html

相关文章:

  • 【Bluetooth】【基础篇】第二章 关于蓝牙协议栈架构与其硬件方案架构大致概述
  • 【JS】JavaScript中的this详解
  • Android 优化 - 日志 Log
  • LeetCode513:找树最左下角的值(bfs+dfs)
  • 【鸿蒙高级】
  • [硬件电路-148]:数字电路 - 什么是CMOS电平、TTL电平?还有哪些其他电平标准?发展历史?
  • 动感按钮:如何打造交互感十足的点击动画效果
  • 【1】WPF界面开发入门—— 图书馆程序:登录界面设计
  • 基于图像识别与分类的中国蛇类识别系统
  • [硬件电路-151]:数字电路 - 模拟电路与数字电路的本质
  • 【数据结构】二叉树的顺序结构实现
  • SQL注入SQLi-LABS 靶场less31-38详细通关攻略
  • 托福阅读38-3
  • 使用AssemblyAI将音频数据转换成文本
  • AI生成图片工具分享!
  • Linux的权限概念
  • 关于Web前端安全之XSS攻击防御增强方法
  • 【视频内容创作】PR的关键帧动画
  • 机器学习第三课之逻辑回归(三)LogisticRegression
  • Python-初学openCV——图像预处理(五)
  • 团队独立思考的力量
  • 论文阅读:DMD蒸馏 | One-step Diffusion with Distribution Matching Distillation
  • Python 动态属性和特性(定义一个特性工厂函数)
  • 「源力觉醒 创作者计划」_文心大模型4.5系列开源模型, 从一行代码到一个生态:聊聊开源战略那些事儿,顺便扯扯文心大模型 4.5 的使用心得
  • zookeeper分布式锁 -- 读锁和写锁实现方式
  • gpu instancer crowd 使用自定义材质并且只修改单个物体的材质参数
  • 【领域热点】【Vue】Vue 与 WebAssembly:前端性能优化的黄金搭档
  • 渗透高级-----应急响应
  • 机器翻译的分类:规则式、统计式、神经式MT的核心区别
  • 新电脑上GitHub推送失败?全面排查与解决指南