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

SpringCloud系列(38)--SpringCloud Gateway实现动态路由

前言:上一节中我们搭建了一个SpringCloud Gateway项目,而在这个项目中我们分别使用到了yml配置文件和编码的方式来对路由进行配置,但随着服务的增加,我们不可能再用指定端口的方式去访问服务,例如我增加多了一个payment服务,新服务的端口为8002,这时候就有两个payment服务,端口分别为8001和8002,如果再用下述的方式来进行路由,就会一直访问端口为8001的服务,所以本节将通过配置动态路由的方式来解决这个问题。

1、动态路由实现原理

默认情况下Gateway会根据注册中心注册的服务列表,以注册中心上微服务名为路径创建动态路由进行转发,从而实现动态路由的功能

2、修改yml配置文件的内容
server:port: 9527
spring:application:name: cloud-gatewaycloud:gateway:discovery:locator:enabled: true #开启从注册中心动态创建路由的功能,利用微服务名进行路由routes:#路由的ID,没有同定规则但要求唯一,建议配合服务名- id: payment_routh#断言,对与路径相匹配的进行路由,即对http://localhost:8001/payment/get/**下的路径进行路由predicates:- Path=/payment/get/**#匹配后提供服务的路由地址#uri: http://localhost:8001#匹配后提供服务的路由地址,lb://表示基于服务注册的负载均衡,lb是loadbalance的缩写uri: lb://cloud-payment-service#路由的ID,没有同定规则但要求唯一,建议配合服务名- id: payment_routh2#断言,对与路径相匹配的进行路由,即对http://localhost:8001/payment/lb/**下的路径进行路由predicates:- Path=/payment/lb/**#匹配后提供服务的路由地址#uri: http://localhost:8001#匹配后提供服务的路由地址,lb://表示基于服务注册的负载均衡,lb是loadbalance的缩写uri: lb://cloud-payment-serviceeureka:instance:hostname: cloud-gateway-serviceclient:#表示是否将自己注册进Eureka Server里,默认为trueregister-with-eureka: true#是否从Eureka Server抓取已有的注册信息,默认为true,单节点无所谓,集群必须设置为true才能配合ribbon使用负载均衡fetch-registry: trueservice-url:defaultZone: http://eureka7001.com:7001/eureka/

3、注释GateWayConfig类关于路由的相关代码
package com.ken.springcloud.config;import org.springframework.cloud.gateway.route.RouteLocator;
import org.springframework.cloud.gateway.route.builder.RouteLocatorBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class GateWayConfig {///**// * 配置一个id为payment_routh的路由规则,当访问地址为http://localhost:9527/payment/get/**时会自动把请求转发到http://localhost:8001/payment/get/**// * @param routeLocatorBuilder// * @return// *///@Bean//public RouteLocator customRouteLocator(RouteLocatorBuilder routeLocatorBuilder) {//    RouteLocatorBuilder.Builder routes = routeLocatorBuilder.routes();//    routes.route("payment_routh", r -> r.path("/payment/get/**").uri("http://localhost:8001")).build();//    return routes.build();//}/////**// * 配置一个id为payment_routh2的路由规则,当访问地址为http://localhost:9527/payment/lb/**时会自动把请求转发到http://localhost:8001/payment/lb/**// * @param routeLocatorBuilder// * @return// *///@Bean//public RouteLocator customRouteLocator2(RouteLocatorBuilder routeLocatorBuilder) {//    RouteLocatorBuilder.Builder routes = routeLocatorBuilder.routes();//    routes.route("payment_routh2", r -> r.path("/payment/lb/**").uri("http://localhost:8001")).build();//    return routes.build();//}}

4、重启cloud-gateway-gateway9527服务,启动provider-payment8002服务

效果图:

5、 在浏览器地址栏输入http://eureka7001.com:7001/然后进入eureka的界面查看cloud-gateway-gateway9527、provider-payment8001、provider-payment8002是否成功注册进

6、 在浏览器的地址栏里输入http://localhost:9527/payment/lb,通过调用接口可以看出我们成功的通过gateway来把请求从对cloud-gateway-gateway9527服务的访问分别动态地转发到了对provider-payment8001服务和provider-payment8002服务的访问

相关文章:

  • SYSCFG 时钟在 GD32F4 系列微控制器中的作用
  • 升级 PowerShell 7
  • elastic-ai.creator开源程序是设计、训练和生成专门针对 FPGA 优化的神经网络
  • 基于 Java+MySQL实现TCP聊天工具
  • MySQL 基线核查实录:标准化配置与命令验证全解析
  • (LeetCode 面试经典 150 题 ) 238. 除自身以外数组的乘积 (前缀和)
  • 考取华为HCIE-AI有什么用?
  • 机器学习3——参数估计之极大似然估计
  • vscode 使用教程
  • 麒麟系统使用-运用VSCode运行.NET工程
  • C++day04(大容量数据、科学记数法、浮点数的格式化)
  • LangChain4j(20)——调用百度地图MCP服务
  • 车载诊断架构--- 车载诊断中的引导式诊断
  • Node.js到底是什么
  • opi是什么
  • 面向大语言模型幻觉的关键数据集:系统性综述与分类法_DEEPSEEK
  • virtual box 配置ubuntu 22.04网络与SSH服务
  • 大模型在急性重型肝炎风险预测与治疗方案制定中的应用研究
  • 力扣刷题(第七十天)
  • 云计算与人工智能的融合:从弹性算力到智能云的IT新革命