java 整合 consul_spring cloud apigateway 与consul 的集成 --Spring boot 2.12

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());

}

};

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值