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/
相关文章推荐
- spring cloud-Feign使用中遇到的问题总结
- 详解spring cloud Feign使用中遇到的问题总结
- spring cloud config使用总结
- spring cloud 之 Feign 使用HTTP请求远程服务
- 关于在Spring Cloud Feign工程中使用Hystrix配置不生效的问题
- 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务
- Spring Cloud中关于Feign的常见问题总结
- spring-cloud-feign使用@RequetParam错误:QueryMap parameter must be a Map: int
- Spring Cloud Feign 的使用注意事项
- (八)SpringBoot+SpringCloud —— 使用Feign消费服务
- Spring Cloud Edgware新特性之三:使用配置属性自定义Feign的行为
- Spring Cloud(Netflix) Feign: 以Dubbo暴露服务的方式使用Feign
- Spring Cloud 的 Hystrix 在 Feign上使用 Hystrix功能
- 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务
- 微服务框架Spring Cloud介绍 Part4: 使用Eureka, Ribbon, Feign实现REST服务客户端
- springcloud-06-feign的使用
- Spring Cloud版——电影售票系统<三>使用Feign实现声明式REST调用
- 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务
- Spring Cloud feign使用
- 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务