Tomcat做爲最經常使用的Java Web服務器,隨着併發量愈來愈高,Tomcat的性能會急劇降低,那有沒有什麼方法來優化Tomcat在高併發環境下的性能呢?java
Tomcat的運行模式有3種。apache
1.bio模式編程
默認的模式,性能很是低下,沒有通過任何優化處理和支持。tomcat
2.nio模式bash
利用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,以下所示。dom
protocol="org.apache.coyote.http11.Http11AprProtocol"
[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
1.JVM 調優
在TOMCAT_HOME/bin/catalina.sh 增長以下語句,具體數值視狀況而定。
添加到上面CATALINA_OPTS的後面便可,以下所示。
JAVA_OPTS=-Xms512m -Xmx1024m -XX:PermSize=512M -XX:MaxNewSize=1024m -XX:MaxPermSize=1024m
參數詳解
建議和注意事項:
-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″ />
若是以爲文章對你有點幫助,請微信搜索並關注「 冰河技術 」微信公衆號,跟冰河學習高併發編程技術。
最後,附上併發編程須要掌握的核心技能知識圖,祝你們在學習併發編程時,少走彎路。