• springCloud feign使用/优化总结


    基于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的URLConnectionApache HttpClient快很多倍。但是Apache HttpClientokhttp都支持配置连接池功能。具体选择需要权衡

    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/

      

  • 相关阅读:
    BZOJ2002 [HNOI2010] 弹飞绵羊
    BZOJ1030 [JSOI2007] 文本生成器
    BZOJ3233 [AHOI2013] 找硬币
    BZOJ4269 再见xor
    BZOJ5297 CQOI2018 社交网络
    LOJ149 0/1分数规划
    BZOJ2132 圈地计划
    UOJ131 [NOI2015] 品酒大会
    composer速度慢(composer更换国内镜像)
    thinkphp6安装报错,composer install tp6 报错 Parse error: syntax error
  • 原文地址:https://www.cnblogs.com/peachyy/p/9729151.html
Copyright © 2020-2023  润新知