feign的超时时间和hystrix的超时时间

直接使用hystrix时:

服务消费方:

@RestController
@RequestMapping("/consumer/users")
public class UserController
{
    @Autowired
    private RestTemplate restTemplate;

    @Autowired
    private DiscoveryClient discoveryClient;

    @GetMapping("{id}")
    // 当此方法无法正常返回的时候 调用降级方法
    @HystrixCommand(fallbackMethod = "getUserByIdFallBack")
    public User getUserById(@PathVariable("id") Long id)
    {
        String url = "http://localhost:8081/users/" + id;
        return restTemplate.getForObject(url, User.class);
    }
    public User getUserByIdFallBack(Long id)
    {
        User user = new User();
        user.setId(-1L);
        user.setName("出现错误");
        return user;
    }
}

yml配置

hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 3000 # 设置hystrix的超时时间为3000ms, 之后才调用降级方法

服务提供方

@RestController
@RequestMapping("/users")
public class UserController
{
    @Autowired
    private IUserService userService;

    @GetMapping("{id}")
    public User getUserById(@PathVariable("id") Long id)
    {
        try
        {
            Thread.sleep(12500); // 远大于三秒
        }
        catch (InterruptedException e)
        {
            e.printStackTrace();
        }
        System.out.println("sb");
        return userService.getUserById(id);
    }
}

此时访问http://localhost/consumer/users/1时, 会因为服务提供方超时而进入降级方法, 并且超时时间恰好是3s

但是如果过通过feign进行调用, hystrix超时时间的配置就会失效
默认情况下: 使用feign进行远程调用, 如果provider中的方法在1s内没有返回, 则会超时报错
如果想延长这个时间就应该设置feign的超时时间
超过feign的超时时间但是没有超过hystrix的超时时间, 还是会进入降级方法

使用feign

服务消费方:

@FeignClient(value = "service-provider", fallback = UserClientFallback.class)
public interface UserClient
{
    @GetMapping("/users/{id}")
    User getUserById(@PathVariable("id") Long id);
}
// 此类用来编写降级方法
@Component
public class UserClientFallback implements UserClient
{
    @Override
    public User getUserById(Long id)
    {
        User user = new User();
        user.setName("UserClientFallback中的降级方法");
        return user;
    }
}
@RestController
@RequestMapping("/consumer/feign/users")
public class UserFeignController
{
    @Autowired
    private UserClient userClient;

    @GetMapping("{id}")
    public User getUserById(@PathVariable("id") Long id)
    {
        return userClient.getUserById(id);
    }
}

yml

feign:
  hystrix:
    enabled: true
  client:
    config:
      default:
        connectTimeout: 2000 # feign 的超时设置
        readTimeout: 2000

此时访问 http://localhost/consumer/feign/users/1 时, 会因为服务提供方超时而进入降级方法, 并且超时时间恰好是2s。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值