當(dāng)前位置:首頁 > 公眾號(hào)精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]來自:冰河技術(shù) 寫在前面 Tomcat作為最常用的Java Web服務(wù)器,隨著并發(fā)量越來越高,Tomcat的性能會(huì)急劇下降,那有沒有什么方法來優(yōu)化Tomcat在高并發(fā)環(huán)境下的性能呢? Tomcat運(yùn)行模式 Tomcat的運(yùn)行模式有3種。 1.bio模式 默認(rèn)的模式,性能非常低下,沒有經(jīng)過任何

高并發(fā)環(huán)境下如何優(yōu)化Tomcat性能?看完我懂了!

來自:冰河技術(shù)

寫在前面

Tomcat作為最常用的Java Web服務(wù)器,隨著并發(fā)量越來越高,Tomcat的性能會(huì)急劇下降,那有沒有什么方法來優(yōu)化Tomcat在高并發(fā)環(huán)境下的性能呢?

Tomcat運(yùn)行模式

Tomcat的運(yùn)行模式有3種。

1.bio模式

默認(rèn)的模式,性能非常低下,沒有經(jīng)過任何優(yōu)化處理和支持。

2.nio模式

利用java的異步io護(hù)理技術(shù),noblocking IO技術(shù)。要想運(yùn)行在該模式下,則直接修改server.xml里的Connector節(jié)點(diǎn),修改protocol為如下配置。

protocol="org.apache.coyote.http11.Http11NioProtocol"

重啟Tomcat后,就可以生效。

3.apr模式

安裝起來最困難,但是從操作系統(tǒng)級(jí)別來解決異步的IO問題,大幅度的提高性能。此種模式下,必須要安裝apr和native,直接啟動(dòng)就支持apr。如nio修改模式,修改protocol為org.apache.coyote.http11.Http11AprProtocol,如下所示。

protocol="org.apache.coyote.http11.Http11AprProtocol"

Tomcat并發(fā)優(yōu)化

安裝APR

[root@binghe ~]# yum -y install apr apr-devel openssl-devel
[root@binghe ~]# tar zxvf tomcat-native.tar.gz
[root@binghe ~]# cd tomcat-native-1.1.24-src/jni/native
[root@binghe native]# ./configure --with-apr=/usr/bin/apr-1-config --with-ssl=/usr/include/openssl/
[root@binghe native]# make && make install

安裝完成之后 會(huì)出現(xiàn)如下提示信息

Libraries have been installed in:
/usr/local/apr/lib

安裝成功后還需要對(duì)tomcat設(shè)置環(huán)境變量,方法是在catalina.sh文件中增加1行:

在這段代碼下面添加:

============
# OS specific support.  $var _must_ be set to either true or false.
cygwin=false
darwin=false
==============
CATALINA_OPTS=”-Djava.library.path=/usr/local/apr/lib”

修改server.xml的配置,如下所示。

protocol=”org.apache.coyote.http11.Http11AprProtocol”

啟動(dòng)tomcat之后,查看日志,如下所示。

more TOMCAT_HOME/logs/catalina.out
2020-04-17 22:34:56 org.apache.catalina.core.AprLifecycleListener init
INFO: Loaded APR based Apache Tomcat Native library 1.1.31 using APR version 1.3.9.
2020-04-17 22:34:56 org.apache.catalina.core.AprLifecycleListener init
INFO: APR capabilities: IPv6 [true], sendfile [true], accept filters [false], random [true].
2020-04-17 22:34:56 org.apache.catalina.core.AprLifecycleListener initializeSSL
INFO: OpenSSL successfully initialized (OpenSSL 1.0.1e 11 Feb 2013)
2020-04-17 22:34:58 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler [“http-apr-8080”]
2020-04-17 22:34:58 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler [“ajp-apr-8009”]
2020-04-17 22:34:58 AM org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 1125 ms

Tomcat優(yōu)化

1.JVM 調(diào)優(yōu)

在TOMCAT_HOME/bin/catalina.sh 增加如下語句,具體數(shù)值視情況而定。
添加到上面CATALINA_OPTS的后面即可,如下所示。

JAVA_OPTS=-Xms512m -Xmx1024m -XX:PermSize=512M -XX:MaxNewSize=1024m -XX:MaxPermSize=1024m

參數(shù)詳解

  • -Xms:JVM初始化堆內(nèi)存大小。

  • -Xmx:JVM堆的最大內(nèi)存。

  • -Xss:線程棧大小。

  • -XX:PermSize:JVM非堆區(qū)初始內(nèi)存分配大小。

  • -XX:MaxPermSize:JVM非堆區(qū)最大內(nèi)存。

建議和注意事項(xiàng):

-Xms和-Xmx選項(xiàng)設(shè)置為相同堆內(nèi)存分配,以避免在每次GC 后調(diào)整堆的大小,堆內(nèi)存建議占內(nèi)存的60%~80%;非堆內(nèi)存是不可回收內(nèi)存,大小視項(xiàng)目而定;線程棧大小推薦256k。

32G內(nèi)存配置如下:

JAVA_OPTS=-Xms20480m -Xmx20480m -Xss1024K -XX:PermSize=512m -XX:MaxPermSize=2048m

2.關(guān)閉DNS反向查詢

在<Connector port=”8080″ 中加入如下參數(shù)。

enableLookups=”false

3.優(yōu)化tomcat參數(shù)

在server.xml文件中進(jìn)行如下配置。

<Connector port=”8080″
protocol=”org.apache.coyote.http11.Http11AprProtocol”
connectionTimeout=”20000″ //鏈接超時(shí)時(shí)長
redirectPort=”8443″
maxThreads=”500″//設(shè)定處理客戶請(qǐng)求的線程的最大數(shù)目,決定了服務(wù)器可以同時(shí)響應(yīng)客戶請(qǐng)求的數(shù),默認(rèn)200
minSpareThreads=”20″//初始化線程數(shù),最小空閑線程數(shù),默認(rèn)為10
acceptCount=”1000″ //當(dāng)所有可以使用的處理請(qǐng)求的線程數(shù)都被使用時(shí),可以被放到處理隊(duì)列中請(qǐng)求數(shù),請(qǐng)求數(shù)超過這個(gè)數(shù)的請(qǐng)求將不予處理,默認(rèn)100
enableLookups=”false”
URIEncoding=”UTF-8″ />

寫在最后

最后,附上并發(fā)編程需要掌握的核心技能知識(shí)圖,祝大家在學(xué)習(xí)并發(fā)編程時(shí),少走彎路。

高并發(fā)環(huán)境下如何優(yōu)化Tomcat性能?看完我懂了!

特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長按關(guān)注一下:

高并發(fā)環(huán)境下如何優(yōu)化Tomcat性能?看完我懂了!

長按訂閱更多精彩▼

高并發(fā)環(huán)境下如何優(yōu)化Tomcat性能?看完我懂了!

如有收獲,點(diǎn)個(gè)在看,誠摯感謝

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉