当前位置: 首页 > 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服务的访问

http://www.lqws.cn/news/541369.html

相关文章:

  • 2024百度之星:BD202404 110串
  • JDY-23蓝牙模块与电脑的连接方式
  • 从0开始学习计算机视觉--Day04--损失函数
  • 杭州西湖断桥不断:3D扫描还原‘残雪‘视觉骗局
  • 在反向代理环境下精准获取客户端真实 IP 的最佳实践
  • Linux journal 日志大小限制与管理详解
  • vue-27(实践练习:将现有组件重构为使用组合式 API)
  • 七天学会SpringCloud分布式微服务——04——Nacos配置中心
  • 便携式水质检测仪的功能
  • 基于 SpringBoot+Vue 的台球厅管理系统的设计与实现(毕业论文)
  • [ linux-系统 ] 磁盘与文件系统
  • 排查 WebView 中 touch、click 事件失效:移动端调试过程详解
  • PIXHAWK(ardupilot4.52)NMEA的解析bug
  • EXCEL数据报表
  • 接口自动化测试框架(pytest+allure+aiohttp+用例自动生成)
  • 【Python基础】05 Python视频压缩技术深度解析
  • 商务创业项目策划计划书PPT模版
  • [Meetily后端框架] 配置指南 | 后端API网关 | API文档体系
  • VB.NET,C#字典对象来保存用户数据,支持大小写
  • Unreal引擎——Chaos物理引擎(不)详解
  • 官方 Linker Scripts 语法和规则解析(2)
  • 《算力迁徙:WebAssembly如何将C++算法炼成前端》
  • 临床项目范围管理:确保项目聚焦与成功交付
  • Flutter 网络请求指南, 从 iOS 到 Flutter 的 Dio + Retrofit 组合
  • 【组管理】创建组删除组修改文件/目录所属组
  • Windows11系统上安装WM虚拟机及Ubuntu 22.04系统
  • 小型软件开发的三重境界:从混沌编码到结构化设计
  • 用3个字符表示2字节二进制数据
  • 【菜狗的记录】模糊聚类最大树、图神经网络、大模型量化——20250627
  • [论文阅读] 人工智能 | 真实场景下 RAG 系统的工程实践指南