在没有使用gateway组件时,实现负载均衡主要是使用ribbon组件,然后就可以使用服务名称的方式访问某一个功能
而在使用gateway时使用静态路由配置不仅会带来文件配置以及代码编写上的麻烦,而且将uri等地址信息写死后也难以实现通过服务名称来访问服务,进而无法实现负载均衡的功能
这里介绍一下gateway动态配置路由的方式
- 环境的配置
环境的配置与gateway静态路由配置的方式相似,这里可以参考gateway静态路由的配置 - 代码的编写
在代码的编写上,与上面链接中文章不同的部分时properties文件的配置
主要是将属性spring.cloud.gateway.discovery.locator.enabled
设置为true
,表示开启从注册中心动态创建路由的功能,利用微服务名称进行路由,然后就可以进行代码的编写了,具体案例如下:
server.port=9527
spring.application.name=cloud-gateway
#ip地址
myIp = localhost
#服务名称
myService =CLOUD-PAYMENT-SERVICE
eureka.instance.hostname=cloud-gateway-service
#eureka的配置
eureka.client.register-with-eureka=true
eureka.client.fetch-registry=true
eureka.client.service-url.defaultZone=http://localhost:7001/eureka
#开启从注册中心动态创建路由的功能,利用微服务名称进行路由
spring.cloud.gateway.discovery.locator.enabled=true
#以下为路由的配置
#路由的id,保持唯一即可
spring.cloud.gateway.routes[0].id=payment_route
#提供服务的路由地址
spring.cloud.gateway.routes[0].uri=lb://${myService}
#断言,路径相匹配的进行路由
spring.cloud.gateway.routes[0].predicates[0]=Path=/payments/get/**