springcloud 系列之 feign 的超时时间 和 zuul 的超时时间

15 篇文章 0 订阅
9 篇文章 0 订阅

今天在做熔断测试的时候 , 关闭 auth 服务 发现 zuul 抛出了一个调用超时的错误 。

com.netflix.zuul.exception.ZuulException: Hystrix Readed time out

不应该啊 , 这个时候不应该是熔断了么 。返回我降级的数据 。(如下) 但是发现并没有

{
    "resultCode": "000000",
    "resultMsg": "操作成功",
    "data": [
        {
            "id": null,
            "menuId": null,
            "userId": null,
            "menuCode": "权限模块调用失败降级返回"
        }
    ]
}

不应该啊  。

原因 : 

zuul 的默认超时时间是 1000ms  feign 的默认超时时间是 1s  所以必定的 zuul 先超时  feign才会进行降级操作 

解决方法 

zuul 设置超时时间  , 并且这个超时时间 要大于 feign的超时时间 。

# zuul 设置超时时间
# 设置zuul的超时时间 , 需要同时设置 ribbon 的 应为zuul 默认是 由 ribbon 实现的
# 注意ribbon的超时时间要小于zuul超时时间 。
ribbon:
  ReadTimeout: 10000
  ConnectTimeout: 10000

feign 的超时时间设置

# 申明 服务降级
feign:
  hystrix:
    enabled: true
# 设置 feign 的超时时间 超过 5s 进行降级返回
hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 5000

我看到有另一种设置方式的 feign 官网 也是这样的(如下)但不知道为什么会没有效果 , 希望有大神看到能解答一下 。自己也要多去找一下问题

feign:
  client:
    config:
      default:
        connectTimeout: 10000
        readTimeout: 10000

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud是一套基于Spring Boot的微服务框架,提供了丰富的组件和工具来构建和管理微服务应用。下面是Spring Cloud常用的注解和代码示例: 1. @EnableDiscoveryClient 该注解用于启用服务注册与发现功能,让应用能够注册到注册中心并进行服务发现。例如: ```java @SpringBootApplication @EnableDiscoveryClient public class ProductServiceApplication { public static void main(String[] args) { SpringApplication.run(ProductServiceApplication.class, args); } } ``` 2. @EnableFeignClients 该注解用于启用Feign客户端的功能,使得应用能够通过Feign调用其他服务的API。例如: ```java @SpringBootApplication @EnableDiscoveryClient @EnableFeignClients public class ProductServiceApplication { public static void main(String[] args) { SpringApplication.run(ProductServiceApplication.class, args); } } ``` 3. @FeignClient 该注解用于定义Feign客户端的接口,并指定要调用的服务的名称。例如: ```java @FeignClient("user-service") public interface UserServiceClient { @GetMapping("/users/{id}") User getUserById(@PathVariable("id") Long id); } ``` 4. @RefreshScope 该注解用于启用配置刷新的功能,让应用能够在运行时动态更新配置。例如: ```java @RestController @RefreshScope public class ConfigController { @Value("${config.key}") private String configValue; @GetMapping("/config") public String getConfigValue() { return configValue; } } ``` 5. @HystrixCommand 该注解用于定义Hystrix断路器的降级方法,当服务调用失败或超时时,自动切换到降级方法。例如: ```java @Service public class UserService { @Autowired private UserServiceClient userServiceClient; @HystrixCommand(fallbackMethod = "getDefaultUser") public User getUserById(Long id) { return userServiceClient.getUserById(id); } private User getDefaultUser(Long id) { return new User(id, "default", ""); } } ``` 6. @EnableZuulProxy 该注解用于启用Zuul网关的功能,使得应用能够进行路由和过滤。例如: ```java @SpringBootApplication @EnableDiscoveryClient @EnableZuulProxy public class ApiGatewayApplication { public static void main(String[] args) { SpringApplication.run(ApiGatewayApplication.class, args); } } ``` 7. @EnableCircuitBreaker 该注解用于启用Hystrix断路器的功能,让应用能够自动处理故障和异常情况。例如: ```java @SpringBootApplication @EnableDiscoveryClient @EnableCircuitBreak

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值