feign超时报错解决

springcloud中a服务通过fegin调b服务如果超时,可能会报下面的错:

Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is com.netflix.hystrix.exception.HystrixRuntimeException: SkuFeign#findByStatusAll(String) timed-out and no fallback available.] with root cause

此时需设置fegin超时时间:

转载:https://www.jianshu.com/p/06f6aa23fc8f

直接使用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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值