SpringCloud成长笔记(六)链路跟踪(Zipkin+rabbitMQ)+Feign性能优化

SpringCloud成长笔记(六)链路跟踪(Zipkin+rabbitMQ)+Feign性能优化)

一、简介

项目上用到的feign用于各个微服务之间的调用,发现调用的响应时间太长,几乎都要1.7秒的时间,这时候就需要想办法优化了。
参考了网上的一些方法,主要是

  • 不使用tomcat,用undtow代替,个人感觉可以使用
  • 配置http连接池,这个是最主要的优化方法
  • 配置hystrix的参数配置

二、环境搭建

<!--优化三:配置http连接池-->
		<dependency>
			<groupId>io.github.openfeign</groupId>
			<artifactId>feign-httpclient</artifactId>
		</dependency>
        <!--优化四:配置hystrix-->
       <!-- <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix</artifactId>
        </dependency>-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>
#性能优化2:undertow配置
server.undertow.max-http-post-size=0
# 设置IO线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程,数量和CPU 内核数目一样即可
server.undertow.io-threads=4
# 阻塞任务线程池, 当执行类似servlet请求阻塞操作, undertow会从这个线程池中取得线程,它的值设置取决于系统的负载  io-threads*8
server.undertow.worker-threads=32
# 以下的配置会影响buffer,这些buffer会用于服务器连接的IO操作,有点类似netty的池化内存管理
# 每块buffer的空间大小,越小的空间被利用越充分
server.undertow.buffer-size=1024
# 每个区分配的buffer数量 , 所以pool的大小是buffer-size * buffers-per-region
#   buffers-per-region: 1024 # 这个参数不需要写了
# 是否分配的直接内存
server.undertow.direct-buffers=true

# 优化三:配置http连接池
# 在feign中开启hystrix功能,默认情况下feign不开启hystrix功能
feign.hystrix.enabled=true
## 配置httpclient线程池
feign.httpclient.enabled=true
feign.okhttp.enabled=false

# 优化四:配置hystrix
#默认参数,作用的所有的hystrix的客户端,如果需要对某个具体的接口,可以写接口+方法名称
hystrix.threadpool.default.coreSize=500
# 是否开启回退方法
hystrix.command.default.fallback.enabled=true
#缺省为1000
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=30000

三、源码

配置http的连接池

四、运行

优化后只用了20多ms的时间。
在这里插入图片描述

五、github源码

Github

六、参考资料

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值