项目版本
<spring-boot.version>2.6.2</spring-boot.version>
<spring-boot-dependencies.version>3.0.0-RC3</spring-boot-dependencies.version>
<spring-cloud.version>3.1.0</spring-cloud.version>
<spring-cloud-dependencies.version>2021.0.0</spring-cloud-dependencies.version>
<spring-cloud-alibaba.version>2021.1</spring-cloud-alibaba.version>
<project.log4j2.version>2.17.1</project.log4j2.version>
getway pom配置
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
<version>${spring-cloud.version}</version>
</dependency>
</dependencies>
getway 配置文件
server:
port: 9999
spring:
application:
name: service-gateway
cloud:
nacos:
discovery:
server-addr: linux101:8800
gateway:
discovery: #是否与服务发现组件进行结合,通过 serviceId(必须设置成大写) 转发到具体的服务实例。默认为false,设为true便开启通过服务中心的自动根据 serviceId 创建路由的功能。
locator: #路由访问方式:http://Gateway_HOST:Gateway_PORT/大写的serviceId/**,其中微服务应用名默认大写访问。
enabled: true
routes:
- id: service-prod
uri: lb://service-prod
name: service-prod
predicates:
- Path=/prod/**
filters:
- StripPrefix=1
问题描述
当uri 为lb时一直503
“status”: 503, “error”: “Service Unavailable”
原因
没有LoadBalancer依赖
加入LoadBalancer依赖即可
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-loadbalancer</artifactId>
<version>${spring-cloud.version}</version>
</dependency>
原理
LoadBalancer 为 getway 提供lb前缀的负载均衡
参考 https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#reactive-loadbalancer-client-filter
项目地址
https://gitee.com/lirongzhen_admin/nacos.git