前言:上一节中我们搭建了一个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是否成功注册进