spring cloud gateway 集成 consul
工程pom.xml 引入 依赖
org.springframework.cloud
spring-cloud-starter-gateway
org.springframework.cloud
spring-cloud-starter-consul-discovery
org.springframework.boot
spring-boot-starter-actuator
在启动类中增加 注解 @EnableDiscoveryClient
在配置中增加网关配置
# tomcat 配置
server:
port: 5000
# 服务名称
spring:
application:
name: api-gateway
cloud:
# consul server地址
consul:
host: localhost
port: 8500
discovery:
# 健康检查 一定要配置 结合 spring-boot-starter-actuator 使用
health-check-path: /actuator/health
health-check-interval: 10s
# 网关配置
gateway:
filter:
remove-non-proxy-headers:
headers:
- dummy
discovery:
locator:
enabled: true
routes:
- id: orderApi
# consul 获取的服务名称 lb -> load balance
uri: lb://order-server
predicates:
- Path=/api/order/**
# 过滤 去掉路径中的 /orderApi
filters:
- StripPrefix=1
- id: commodityApi
# consul 获取的服务名称 lb -> load balance
uri: lb://commodity-server
predicates:
- Path=/api/commodity/**
# 过滤 去掉路径中的 /api
filters:
- StripPrefix=1
gateway 自带限流功能 需要 redis 依赖支持
org.springframework.boot
spring-boot-starter-data-redis-reactive
配置需要同步修改
routes:
- id: payApi
# consul 获取的服务名称 lb -> load balance
uri: lb://pay-server
predicates:
- Path=/api/pay/**
# 过滤 去掉路径中的 /orderApi
filters:
- StripPrefix=1
# 限流操作
- name: RequestRateLimiter
args:
# 允许用户每秒处理多少个请求
redis-rate-limiter.replenishRate: 10
# 令牌桶的容量,允许在一秒钟内完成的最大请求数
redis-rate-limiter.burstCapacity: 20
# ip 限流 bean
key-resolver: "#{@ipKeyResolver}"
注入自定义限流类型(针对 ip 限流)
@Bean
public KeyResolver ipKeyResolver() {
return new KeyResolver() {
@Override
public Mono resolve(final ServerWebExchange exchange) {
return Mono.just(exchange.getRequest().getRemoteAddress().getHostName());
}
};
}