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

发布于:2025-06-28 ⋅ 阅读:(13) ⋅ 点赞:(0)

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

1、动态路由实现原理

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

2、修改yml配置文件的内容
server:
  port: 9527
spring:
  application:
    name: cloud-gateway
  cloud:
    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-service

eureka:
  instance:
    hostname: cloud-gateway-service
  client:
    #表示是否将自己注册进Eureka Server里,默认为true
    register-with-eureka: true
    #是否从Eureka Server抓取已有的注册信息,默认为true,单节点无所谓,集群必须设置为true才能配合ribbon使用负载均衡
    fetch-registry: true
    service-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服务的访问


网站公告

今日签到

点亮在社区的每一天
去签到