温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

spring cloud apigateway与consul的集成分析

发布时间:2021-11-15 17:17:41 来源:亿速云 阅读:393 作者:iii 栏目:大数据

本篇内容介绍了“spring cloud apigateway与consul的集成分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

spring cloud gateway 集成 consul

工程pom.xml 引入 依赖

<dependency>     <groupId>org.springframework.cloud</groupId>     <artifactId>spring-cloud-starter-gateway</artifactId> </dependency> <dependency>     <groupId>org.springframework.cloud</groupId>     <artifactId>spring-cloud-starter-consul-discovery</artifactId> </dependency> <dependency>     <groupId>org.springframework.boot</groupId>     <artifactId>spring-boot-starter-actuator</artifactId> </dependency>

在启动类中增加 注解 @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 依赖支持

<dependency>     <groupId>org.springframework.boot</groupId>     <artifactId>spring-boot-starter-data-redis-reactive</artifactId> </dependency>

配置需要同步修改

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<String> resolve(final ServerWebExchange exchange) {             return Mono.just(exchange.getRequest().getRemoteAddress().getHostName());         }     }; }

在集成过程中有个深坑,就是配置限流操作的时候,本地的redis 没有启动,导致consul的helath check一直是down状态

要解决health check问题 需要把 health check的详细返回打开, 再次调用/actuator/health接口会把详情返回了。

management:   endpoint:     health:       show-details: always

“spring cloud apigateway与consul的集成分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI