SpringCloud eureka 重试机制ribbon,熔断器Hystrix,简化远程调用Feign

本文介绍了如何在SpringCloud中使用Ribbon的重试机制,详细阐述了Hystrix的熔断功能以及如何将两者结合以实现先重试后熔断。此外,还探讨了Feign的使用,包括入门和优化,如负载均衡和Hystrix支持,以简化远程调用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.重试机制 ribbon

1.1 解释:当一次服务调用失败后,不会立即抛出异常,而是再次重试另一个服务。
1.2 实现步骤:
  • 在服务调用端配置文件中开启重试机制
spring: 
  cloud:
    loadbalancer:
      retry:
        enabled: true # 开启Spring Cloud的重试功能
service:  #负载均衡规则的配置
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule  #规则:随机________默认:轮循
    ConnectTimeout: 250 # Ribbon的连接超时时间
    ReadTimeout: 1000 # Ribbon的数据读取超时时间
    OkToRetryOnAllOperations: true # 是否对所有操作都进行重试
    MaxAutoRetriesNextServer: 1 # 切换实例的重试次数
    MaxAutoRetries: 1 # 对当前实例的重试次数
  • pom文件添加依赖
<dependency>
	<groupId>org.springframework.retry</groupId>
	<artifactId>spring-retry</artifactId>
</dependency>
  • 运行测试

当多个消息提供端关闭一个,不会有请求返回异常,经过连接超时时间就会返回所有响应数据

  • 跟踪源码,查看ip地址:
    双击Shift键,搜索LoadBalancerInterceptor–>
    双击Shift键,搜索LoadBalancerlnterceptor–>
    通过intercept方法,点击返回函数execute方法–>
    ctrl + alt +B查找实现类–>
    execute方法处加断点

2.熔断器 Hystrix

2.1 简介 :

Hystrix是Netflix开源的一个延迟和容错库,用于隔离访问远程服务、第三方库,防止出现级联失败。

2.2 功能 :

当服务繁忙时,如果服务出现异常&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值