电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Cloud Feign性能優(yōu)化代碼實(shí)例

瀏覽:90日期:2023-09-18 17:24:05

1、替換 tomcat

首先,把 tomcat 換成 undertow,這個(gè)性能在 Jmeter 的壓測(cè)下,undertow 比 tomcat 高一倍第一步,pom 修改去除tomcat

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions></dependency><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-undertow</artifactId></dependency>

第二步,配置

server: undertow: max-http-post-size: 0# 設(shè)置IO線程數(shù), 它主要執(zhí)行非阻塞的任務(wù),它們會(huì)負(fù)責(zé)多個(gè)連接, 默認(rèn)設(shè)置每個(gè)CPU核心一個(gè)線程,數(shù)量和CPU 內(nèi)核數(shù)目一樣即可 io-threads: 4# 阻塞任務(wù)線程池, 當(dāng)執(zhí)行類似servlet請(qǐng)求阻塞操作, undertow會(huì)從這個(gè)線程池中取得線程,它的值設(shè)置取決于系統(tǒng)的負(fù)載 io-threads*8 worker-threads: 32# 以下的配置會(huì)影響buffer,這些buffer會(huì)用于服務(wù)器連接的IO操作,有點(diǎn)類似netty的池化內(nèi)存管理# 每塊buffer的空間大小,越小的空間被利用越充分 buffer-size: 1024# 每個(gè)區(qū)分配的buffer數(shù)量 , 所以pool的大小是buffer-size * buffers-per-region# buffers-per-region: 1024 # 這個(gè)參數(shù)不需要寫了# 是否分配的直接內(nèi)存 direct-buffers: true

2、替換 HTTPClient

第一步,加依賴

<dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-httpclient</artifactId></dependency>

第二部,在 application.yml或者 bootstrap.yml 里面配置

# feign配置feign: hystrix: # 在feign中開啟hystrix功能,默認(rèn)情況下feign不開啟hystrix功能 enabled: true ## 配置httpclient線程池 httpclient: enabled: true okhttp: enabled: false

第三步,配置 HTTPClient Bean

import java.util.Timer;import java.util.TimerTask;import java.util.concurrent.TimeUnit;import org.apache.http.client.HttpClient;import org.apache.http.client.config.RequestConfig;import org.apache.http.impl.client.DefaultConnectionKeepAliveStrategy;import org.apache.http.impl.client.HttpClientBuilder;import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;@Configurationpublic class HttpPool { @Bean public HttpClient httpClient(){ System.out.println('===== Apache httpclient 初始化連接池開始===' ); // 生成默認(rèn)請(qǐng)求配置 RequestConfig.Builder requestConfigBuilder = RequestConfig.custom(); // 超時(shí)時(shí)間 requestConfigBuilder.setSocketTimeout(5 * 1000); // 連接時(shí)間 requestConfigBuilder.setConnectTimeout(5 * 1000); RequestConfig defaultRequestConfig = requestConfigBuilder.build(); // 連接池配置 // 長(zhǎng)連接保持30秒 final PoolingHttpClientConnectionManager pollingConnectionManager = new PoolingHttpClientConnectionManager(30, TimeUnit.MILLISECONDS); // 總連接數(shù) pollingConnectionManager.setMaxTotal(1000); // 同路由的并發(fā)數(shù) pollingConnectionManager.setDefaultMaxPerRoute(100); // httpclient 配置 HttpClientBuilder httpClientBuilder = HttpClientBuilder.create(); // 保持長(zhǎng)連接配置,需要在頭添加Keep-Alive httpClientBuilder.setKeepAliveStrategy(new DefaultConnectionKeepAliveStrategy()); httpClientBuilder.setConnectionManager(pollingConnectionManager); httpClientBuilder.setDefaultRequestConfig(defaultRequestConfig); HttpClient client = httpClientBuilder.build(); // 啟動(dòng)定時(shí)器,定時(shí)回收過期的連接 Timer timer = new Timer(); timer.schedule(new TimerTask() { @Override public void run() {System.out.println('=====closeIdleConnections===');pollingConnectionManager.closeExpiredConnections();pollingConnectionManager.closeIdleConnections(5, TimeUnit.SECONDS); } }, 10 * 1000, 5 * 1000); System.out.println('===== Apache httpclient 初始化連接池完畢==='); return client; }}

3、配置 Hystrix

第一步,依賴

<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId></dependency>

第二步,配置

# 配置hystrix的參數(shù)hystrix: threadpool: # default: 默認(rèn)參數(shù),作用的所有的hystrix的客戶端,如果需要對(duì)某個(gè)具體的接口,可以寫接口 方法名稱 default: coreSize: 500 command: default: fallback: # 是否開啟回退方法 enabled: true execution: isolation: thread: timeoutInMilliseconds: 30000 #缺省為1000

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: ETFE膜结构_PTFE膜结构_空间钢结构_膜结构_张拉膜_浙江萬豪空间结构集团有限公司 | 上海小程序开发-上海小程序制作公司-上海网站建设-公众号开发运营-软件外包公司-咏熠科技 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 最新范文网_实用的精品范文美文网 | 衬塑设备,衬四氟设备,衬氟设备-淄博鲲鹏防腐设备有限公司 | 浙江建筑资质代办_二级房建_市政_电力_安许_劳务资质办理公司 | 高硼硅玻璃|水位计玻璃板|光学三棱镜-邯郸奥维玻璃科技有限公司 高温高压釜(氢化反应釜)百科 | 三效蒸发器_多效蒸发器价格_四效三效蒸发器厂家-青岛康景辉 | 传爱自考网_传爱自学考试网| 深圳诚暄fpc首页-柔性线路板,fpc柔性线路板打样生产厂家 | 新疆十佳旅行社_新疆旅游报价_新疆自驾跟团游-新疆中西部国际旅行社 | 减速机电机一体机_带电机减速器一套_德国BOSERL电动机与减速箱生产厂家 | 特材真空腔体_哈氏合金/镍基合金/纯镍腔体-无锡国德机械制造有限公司 | 台湾Apex减速机_APEX行星减速机_台湾精锐减速机厂家代理【现货】-杭州摩森机电 | 西安微信朋友圈广告投放_微信朋友圈推广_西安度娘网络科技有限公司 | 汽车润滑油厂家-机油/润滑油代理-高性能机油-领驰慧润滑科技(河北)有限公司 | 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 | 全自动在线分板机_铣刀式在线分板机_曲线分板机_PCB分板机-东莞市亿协自动化设备有限公司 | 软启动器-上海能曼电气有限公司 真空搅拌机-行星搅拌机-双行星动力混合机-广州市番禺区源创化工设备厂 | TPE塑胶原料-PPA|杜邦pom工程塑料、PPSU|PCTG材料、PC/PBT价格-悦诚塑胶 | 福建珂朗雅装饰材料有限公司「官方网站」 | 高压无油空压机_无油水润滑空压机_水润滑无油螺杆空压机_无油空压机厂家-科普柯超滤(广东)节能科技有限公司 | 环境模拟实验室_液体-气体控温机_气体控温箱_无锡双润冷却科技有限公司 | 桐城新闻网—桐城市融媒体中心主办 | 合肥弱电工程_安徽安防工程_智能化工程公司-合肥雷润 | 电子海图系统-电梯检验系统-智慧供热系统开发-商品房预售资金监管系统 | 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | 点胶机_点胶阀_自动点胶机_智能点胶机_喷胶机_点胶机厂家【欧力克斯】 | 远程会诊系统-手术示教系统【林之硕】医院远程医疗平台 | 护腰带生产厂家_磁石_医用_热压护腰_登山护膝_背姿矫正带_保健护具_医疗护具-衡水港盛 | 深圳宣传片制作_产品视频制作_深圳3D动画制作公司_深圳短视频拍摄-深圳市西典映画传媒有限公司 | 铝单板_铝窗花_铝单板厂家_氟碳包柱铝单板批发价格-佛山科阳金属 | 微型气象仪_气象传感器_防爆气象传感器-天合传感器大全 | 全国国际化学校_国际高中招生_一站式升学择校服务-国际学校网 | 跨境物流_美国卡派_中大件运输_尾程派送_海外仓一件代发 - 广州环至美供应链平台 | 翅片管散热器价格_钢制暖气片报价_钢制板式散热器厂家「河北冀春暖气片有限公司」 | 高效复合碳源-多核碳源生产厂家-污水处理反硝化菌种一长隆科技库巴鲁 | 产业规划_产业园区规划-产业投资选址及规划招商托管一体化服务商-中机院产业园区规划网 | BAUER减速机|ROSSI-MERSEN熔断器-APTECH调压阀-上海爱泽工业设备有限公司 | 净化板-洁净板-净化板价格-净化板生产厂家-山东鸿星新材料科技股份有限公司 | 固诺家居-全屋定制十大品牌_整体衣柜木门橱柜招商加盟 |