本文介绍Java的动态路由中间件:router4j。router4j用于SpringCloud项目,它可以将某个url请求路由到指定的机器上,也可以将所有请求强制转到指定机器。
问题描述
Java后端在开发SpringCloud项目时如果同一个应用起了多个实例,会遇到以下问题:
本文介绍的router4j可以解决这个问题,是我个人写的中间件。它可以设置将指定的url的请求路由到指定的机器。
官网网址
官网文档:router4j官网(首先在官网更新,不定时同步到CSDN博客)
github:https://github.com/knife-blade/router4j
gitee:https://gitee.com/knifeedge/router4j
router4j是一个动态路由的中间件,用于提高Java后端开发和调试效率。
使用router4j,可以将某个url请求路由到指定的机器上,只需在可视化页面上将path绑定到应用实例的ip和端口上即可。
router4j也支持将所有请求强制转到指定机器,所以也可以用于线上不停机更新应用。
1.在可视化页面进行配置,将url与实例(ip加端口)关联起来
2.前端请求进来时:gateway会使用本框架的全局过滤器,会根据这个url到Redis中的配置中查询,将url路由到指定的实例(ip加端口)
3.调用feign时:feign会使用本框架的负载均衡器,会根据这个url到Redis中的配置中查询,将url路由到指定的实例(ip加端口)
github:https://github.com/knife-blade/router4j
gitee:https://gitee.com/knifeedge/router4j
备注:本文依赖已上传到maven中央仓库、maven阿里云镜像。
gateway网关和应用都添加依赖
- <dependency>
- <groupId>com.suchtool</groupId>
- <artifactId>router4j-client-spring-boot-starter</artifactId>
- <version>1.0.0</version>
- </dependency>
此依赖会自动识别是网关还是应用,自动启用动态路由策略。
网关和应用都要添加如下配置(放到application.yml等配置文件即可):
- suchtool:
- router4j:
- redis:
- host: localhost
- password: 222333
- port: 6379
- # database: 0
- # ssl: false
- # timeout: 3s
- rule:
- enable: true
- # pathPatternPrefix: "router4j:rule:pathPattern"
- # defaultInstancePrefix: "router4j:rule:defaultInstance"
启动Nacos、Redis。本处省略。
1.启动控制台
启动router4j-server(Java程序)。可通过IDEA或者java -jar启动(后期会提供docker镜像)。
本处我使用java命令启动:
java -jar router4j-server-1.0.0.jar
运行结果如下:
启动示例服务:gateway、业务应用(2个order,2个storage,1个account)。
业务场景:创建订单,减库存、减账户余额。请求order的controller,order分别用feign调用storage和account。
需求:将网关请求order的/order/create转发到192.168.5.1:9011这个实例,将对storage的所有请求转发到192.168.5.1:9021这个实例。
1.配置路径的路由规则
访问router4j控制台:http://localhost:9900
在“规则管理”中配置路径与实例的绑定:
2.请求接口测试
postman访问(请求10次):http://localhost:6001/order/order/create/?userId=1&productId=1&count=10&money=100
结果:
order:(全部都请求到了指定的实例192.168.5.1:9011)
storage:(全部都请求到了指定的实例192.168.5.1:9021)
3.测试默认的路由策略
上边介绍了本组件的作用,如果没有使用router4j去指定,请求会被负载均衡到不同的机器上。
下边我把规则管理里的配置给删掉:
请求10次进行测试:
网关请求到order,每个order实例收到了5次请求:
order通过feign请求到storage,每个storage实例收到了5次请求
底层是基于Spring自身的AntPathMatcher来实现的,其规则见:此文
支持手动输入
支持下拉框选择和手动输入
支持单个删除(绿色箭头所指)和批量删除(红色箭头所指)。
所有实例列表
对于Nacos,有命名空间,在右上角选择命名空间后,再点击一下搜索,即可展示所有的实例
对于Eureka,右上角不会展示命名空间。
设置为默认路由
默认路由的作用:如果url没有设置规则,则转发到设置的默认路由的实例。
支持单个设置(绿色箭头)与批量设置(红色箭头)。
强制路由的作用:所有url强制路由到指定实例(无论是否设置了规则)。
注意:在选择强制路由后,默认路由也会自动被选中。
支持单个设置(绿色箭头)与批量设置(红色箭头)。