【高併發】高併發環境下如何優化Tomcat效能?看完我懂了!

冰河團隊發表於2020-04-17

寫在前面

Tomcat作為最常用的Java Web伺服器,隨著併發量越來越高,Tomcat的效能會急劇下降,那有沒有什麼方法來優化Tomcat在高併發環境下的效能呢?

Tomcat執行模式

Tomcat的執行模式有3種。

1.bio模式

預設的模式,效能非常低下,沒有經過任何優化處理和支援。

2.nio模式

利用java的非同步io護理技術,noblocking IO技術。要想執行在該模式下,則直接修改server.xml裡的Connector節點,修改protocol為如下配置。

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

重啟Tomcat後,就可以生效。

3.apr模式

安裝起來最困難,但是從作業系統級別來解決非同步的IO問題,大幅度的提高效能。此種模式下,必須要安裝apr和native,直接啟動就支援apr。如nio修改模式,修改protocol為org.apache.coyote.http11.Http11AprProtocol,如下所示。

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

Tomcat併發優化

安裝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

安裝完成之後 會出現如下提示資訊

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

安裝成功後還需要對tomcat設定環境變數,方法是在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優化

1.JVM 調優

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

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

引數詳解

  • -Xms:JVM初始化堆記憶體大小。
  • -Xmx:JVM堆的最大記憶體。
  • -Xss:執行緒棧大小。
  • -XX:PermSize:JVM非堆區初始記憶體分配大小。
  • -XX:MaxPermSize:JVM非堆區最大記憶體。

建議和注意事項:

-Xms和-Xmx選項設定為相同堆記憶體分配,以避免在每次GC 後調整堆的大小,堆記憶體建議佔記憶體的60%~80%;非堆記憶體是不可回收記憶體,大小視專案而定;執行緒棧大小推薦256k。

32G記憶體配置如下:

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

2.關閉DNS反向查詢

在<Connector port=”8080″ 中加入如下引數。

enableLookups=”false”

3.優化tomcat引數

在server.xml檔案中進行如下配置。

<Connector port=”8080″
protocol=”org.apache.coyote.http11.Http11AprProtocol”
connectionTimeout=”20000″ //連結超時時長
redirectPort=”8443″
maxThreads=”500″//設定處理客戶請求的執行緒的最大數目,決定了伺服器可以同時響應客戶請求的數,預設200
minSpareThreads=”20″//初始化執行緒數,最小空閒執行緒數,預設為10
acceptCount=”1000″ //當所有可以使用的處理請求的執行緒數都被使用時,可以被放到處理佇列中請求數,請求數超過這個數的請求將不予處理,預設100
enableLookups=”false”
URIEncoding=”UTF-8″ />

寫在最後

如果覺得文章對你有點幫助,請微信搜尋並關注「 冰河技術 」微信公眾號,跟冰河學習高併發程式設計技術。

最後,附上併發程式設計需要掌握的核心技能知識圖,祝大家在學習併發程式設計時,少走彎路。
sandahexin_20200322

相關文章