您的位置:首页 > 编程语言 > Java开发

springCloud feign使用/优化总结

2018-09-30 13:14 716 查看

基于springCloud Dalston.SR3版本

 

1.当接口参数是多个的时候 需要指定@RequestParam 中的value来明确一下。

/**
* 用户互扫
* @param uid 被扫人ID
* @param userId 当前用户ID
* @return
*/
@PostMapping(REQ_URL_PRE + "/qrCodeReturnUser")
UserQrCode qrCodeReturnUser(@RequestParam("uid") String uid,@RequestParam("userId") Integer userId);

2.接口参数为对象的时候 需要使用@RequestBody注解 并采用POST方式。

3.如果接口是简单的数组/列表参数 这里需要使用Get请求才行

@GetMapping(REQ_URL_PRE + "/getUserLevels")
Map<Integer, UserLevel> getUserLevels(@RequestParam("userIds") List<Integer> userIds);

4.直接可以在
@FeignClient
中配置降级处理方式 对于一些不重要的业务 自定义处理很有帮助

@FeignClient(value = "cloud-user", fallback = IUsers.UsersFallback.class)

5.
feign
默认只有
HystrixBadRequestException
异常不会走熔断,其它任何异常都会进入熔断,需要重新实现一下
ErrorDecoder
包装业务异常

示例:https://github.com/peachyy/feign-support

6. feign HTTP请求方式选择

feign
默认使用的是基于JDK提供的URLConnection调用HTTP接口,不具备连接池。所以资源开销上有点影响,经测试JDK的
URLConnection
Apache HttpClient
快很多倍。但是
Apache HttpClient
okhttp
都支持配置连接池功能。具体选择需要权衡

7.默认不启用
hystrix
 需要手动指定
feign.hystrix.enabled=true
 开启熔断

8.启用压缩也是一种有效的优化方式

feign.compression.request.enabled=true
feign.compression.response.enabled=true
feign.compression.request.mime-types=text/xml,application/xml,application/json

  

9.参数相关调优

  hystrix线程数设置

 设置参数

hystrix.threadpool.default.coreSize
 来指定熔断隔离的线程数 这个数需要调优,经测试 线程数我们设置为和提供方的容器线程差不多,吞吐量高许多。

  第一次访问服务出错的问题

    启用

Hystrix
后,很多服务当第一次访问的时候都会失败 是因为初始化负载均衡一系列操作已经超出了超时时间了 默认的超时时间为
1S
,设置参数超时时间
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=30000
 可解决这个问题。

  负载均衡参数设置

  设置了

Hystrix
的超时参数会 还需设置一下
ribbon
的相关参数 这些参数和
Hystrix
的超时参数有一定的逻辑关系
       请求处理的超时时间 
ribbon.ReadTimeout=120000

      请求连接的超时时间 
ribbon.ConnectTimeout=30000

 

 

原文:http://blog.seoui.com/2018/09/30/springcloud-feign/

  

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: