高并發(fā)環(huán)境下如何優(yōu)化Tomcat性能?看完我懂了!
來自:冰河技術
寫在前面
Tomcat作為最常用的Java Web服務器,隨著并發(fā)量越來越高,Tomcat的性能會急劇下降,那有沒有什么方法來優(yōu)化Tomcat在高并發(fā)環(huán)境下的性能呢?
Tomcat運行模式
Tomcat的運行模式有3種。
1.bio模式
默認的模式,性能非常低下,沒有經(jīng)過任何優(yōu)化處理和支持。
2.nio模式
利用java的異步io護理技術,noblocking IO技術。要想運行在該模式下,則直接修改server.xml里的Connector節(jié)點,修改protocol為如下配置。
protocol="org.apache.coyote.http11.Http11NioProtocol"
重啟Tomcat后,就可以生效。
3.apr模式
安裝起來最困難,但是從操作系統(tǒng)級別來解決異步的IO問題,大幅度的提高性能。此種模式下,必須要安裝apr和native,直接啟動就支持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
安裝完成之后 會出現(xiàn)如下提示信息
Libraries have been installed in:
/usr/local/apr/lib
安裝成功后還需要對tomcat設置環(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”
啟動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 調優(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初始化堆內存大小。
-Xmx:JVM堆的最大內存。
-Xss:線程棧大小。
-XX:PermSize:JVM非堆區(qū)初始內存分配大小。
-XX:MaxPermSize:JVM非堆區(qū)最大內存。
建議和注意事項:
-Xms和-Xmx選項設置為相同堆內存分配,以避免在每次GC 后調整堆的大小,堆內存建議占內存的60%~80%;非堆內存是不可回收內存,大小視項目而定;線程棧大小推薦256k。
32G內存配置如下:
JAVA_OPTS=-Xms20480m -Xmx20480m -Xss1024K -XX:PermSize=512m -XX:MaxPermSize=2048m
2.關閉DNS反向查詢
在<Connector port=”8080″ 中加入如下參數(shù)。
enableLookups=”false”
3.優(yōu)化tomcat參數(shù)
在server.xml文件中進行如下配置。
<Connector port=”8080″
protocol=”org.apache.coyote.http11.Http11AprProtocol”
connectionTimeout=”20000″ //鏈接超時時長
redirectPort=”8443″
maxThreads=”500″//設定處理客戶請求的線程的最大數(shù)目,決定了服務器可以同時響應客戶請求的數(shù),默認200
minSpareThreads=”20″//初始化線程數(shù),最小空閑線程數(shù),默認為10
acceptCount=”1000″ //當所有可以使用的處理請求的線程數(shù)都被使用時,可以被放到處理隊列中請求數(shù),請求數(shù)超過這個數(shù)的請求將不予處理,默認100
enableLookups=”false”
URIEncoding=”UTF-8″ />
寫在最后
最后,附上并發(fā)編程需要掌握的核心技能知識圖,祝大家在學習并發(fā)編程時,少走彎路。
特別推薦一個分享架構+算法的優(yōu)質內容,還沒關注的小伙伴,可以長按關注一下:
長按訂閱更多精彩▼
如有收獲,點個在看,誠摯感謝
免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!