www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 公眾號精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]一、前言 tomcat 服務(wù)器在JavaEE項(xiàng)目中使用率非常高,所以在生產(chǎn)環(huán)境對tomcat的優(yōu)化也變得非常重要了,對于tomcat的優(yōu)化,主要是從2個方面入手,一是tomcat本身的配置,另一個是tomcat所運(yùn)行的Jvm虛擬機(jī)的調(diào)優(yōu) 二、Tomcat配置優(yōu)化 2.1 下載安裝tomcat 案例中

一、前言

tomcat 服務(wù)器在JavaEE項(xiàng)目中使用率非常高,所以在生產(chǎn)環(huán)境對tomcat的優(yōu)化也變得非常重要了,對于tomcat的優(yōu)化,主要是從2個方面入手,一是tomcat本身的配置,另一個是tomcat所運(yùn)行的Jvm虛擬機(jī)的調(diào)優(yōu)

二、Tomcat配置優(yōu)化

2.1 下載安裝tomcat

案例中使用的Tomcat版本是 8.0+ 版本

下載安裝:https://tomcat.apache.org/download-80.cgi

2.2 配置修改

# 進(jìn)入tomcat配置文件夾cd apache-tomcat-8.5.47/conf/# 需要配置文件,配置tomcat的管理用戶vim tomcat-users.xml 

寫入以下內(nèi)容:

 <role rolename="manager"/> <role rolename="manager-gui"/> <role rolename="admin"/> <role rolename="admin-gui"/> <user username="tomcat" password="tomcat" roles="admin-gui,admin,manager-gui,manager"/> # 保存退出# 如果是tomcat7,配置了tomcat用戶就可以登錄系統(tǒng)了,但是tomcat8中不行# 還需要修改下面一個配置文件,否則訪問不了,提示403  vim cd webapps/manager/META-INF/context.xml<Context antiResourceLocking="false" privileged="true" > <Manager sessionAttributeValueClassNameFilter="java\.lang\.(?:Boolean|Integer|Long|Number|String)|org\.apache\.catalina\.filters\.CsrfPreventionFilter\$LruCache(?:\$1)?|java\.util\.(?:Linked)?HashMap"/>Context> # 保存退出即可# 啟動tomcat

2.33 啟動訪問

成功訪問tomcat地址后,點(diǎn)擊 首頁中 ServerStatus,輸入用戶名密碼 tomcat/tomcat

提高網(wǎng)站訪問性能——Tomcat優(yōu)化進(jìn)入頁面,我們需要關(guān)注的就是其中JVM的列表參數(shù):

Eden Space:年輕代中的Eden區(qū)

Survivor Space:年輕代中的Survivor 區(qū)

Tenured Gen:老年代-養(yǎng)老區(qū)

其中 EdenSpace、SurvivorSpace、TenuredGen屬于堆內(nèi)存,而下面的三個( CodeCacheCompressedClassSpace、Metaspace)屬于非堆內(nèi)存

Code Cache:代碼緩存區(qū)

Compressed Class Space:壓縮類空間

Metaspace:元空間

三、Tomcat優(yōu)化

3.1 禁用AJP連接

在服務(wù)狀態(tài)頁面可以看到,默認(rèn)狀態(tài)下回啟用AJP連接,并且占用 8011端口提高網(wǎng)站訪問性能——Tomcat優(yōu)化什么是AJP呢?

AJP(Apache jServer Protocol) AJP13協(xié)議是面向包的,WEB服務(wù)器和Servlet容器通過TCP連接來交互;為了節(jié)省SOCKET創(chuàng)建的昂貴代價,WEB服務(wù)器會嘗試維護(hù)一個永久TCP容器,并且在多個請求赫爾響應(yīng)周期過程會重用連接。

web客戶端訪問tomcat服務(wù)器上的JSP組件的兩種方式,如下圖所示:提高網(wǎng)站訪問性能——Tomcat優(yōu)化我們一般是使用Nginx+tomcat的架構(gòu),所以用不著AJP協(xié)議,所以把AJP連接禁用。修改conf下的Server.xml文件,將AJP服務(wù)禁用掉即可。

					
  1. port="8011" protocol="AJP/1.3" redirectPort="8443" />

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

重啟tomcat,查看效果:可以看到AJP服務(wù)已經(jīng)不存在了

3.2 執(zhí)行器(線程池)

在tomcat中每一個用戶請求都是一個線程,所以可以使用線程池提高性能 修改conf/server.xml文件:

<Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50"  prestartminSpareThreads="true" maxQueueSize="100"/>    <Connector executor="tomcatThreadPool" port="8000"  protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

保存退出,重啟tomcat,查看效果

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

在頁面中現(xiàn)實(shí)最大線程為 -1 ,這個是正常的,只是顯示的問題,實(shí)際使用的指定的值

3.3 tomcat的三種運(yùn)行模式

tomcat的運(yùn)行模式有三種:

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

  • nio: (new I/O),是Java SE 1.4及后續(xù)版本提供的一種新的 I/O操作方式(即java.nio包及其子包),java nio是一個基于緩沖區(qū),并能提供非阻塞I/O操作的java API ,因此nio也被看成是 non-blocking I/O的縮寫,它擁有比傳統(tǒng)I/O操作(bio)更好的并發(fā)運(yùn)行性能

  • apr: 安裝起來最困難,不過在tomcat8中有最新的nio2,速度更快,建議使用nio2

設(shè)置nio2:

<Connector executor="tomcatThreadPool" port="8000" protocol="org.apache.coyote.http11.Http11Nio2Protocol" connectionTimeout="20000" redirectPort="8443" />

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

四、性能測試

4.1 使用Apache Jmeter 進(jìn)行測試

Apache Jmeter 是開源的壓力測試工具,我們借助此工具進(jìn)行測試,將測試出tomcat的吞吐量等信息

4.1.1 下載安裝

下載地址:http://jmeter.apache.org/download_jmeter.cgi

進(jìn)入bin目錄,找到meter.bat文件,雙擊打開即可啟動。提高網(wǎng)站訪問性能——Tomcat優(yōu)化

注意:如果想要效果更好的體現(xiàn)最好使用一個項(xiàng)目demo進(jìn)行測試

4.1.2 配置

第一步:保存測試用例

第二步:添加線程組,使用線程模擬用戶的并發(fā)提高網(wǎng)站訪問性能——Tomcat優(yōu)化1000個線程,每個線程循環(huán)10次,也就是tomcat會接收到10000個請求提高網(wǎng)站訪問性能——Tomcat優(yōu)化第三步:添加http請求 這里我使用的是我的測試項(xiàng)目提高網(wǎng)站訪問性能——Tomcat優(yōu)化提高網(wǎng)站訪問性能——Tomcat優(yōu)化

第四步:添加請求監(jiān)控提高網(wǎng)站訪問性能——Tomcat優(yōu)化

4.1.3 啟動測試:

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

其中我們需要關(guān)注的就是 聚合報(bào)告 的數(shù)據(jù)

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

4.2 禁用AJP服務(wù)

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

可以看到,禁用AJP服務(wù)后,平均響應(yīng)時間和吞吐量會有所提升,不過測試不一定準(zhǔn)確,需要多測試幾次才能看出來是否有提升。

4.3 設(shè)置線程池

通過審核制線程池,調(diào)整線程池相關(guān)的參數(shù)進(jìn)行測試tomcat的性能

4.3.1 最大線程數(shù)為500,初始為50
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>

測試結(jié)果:提高網(wǎng)站訪問性能——Tomcat優(yōu)化

吞吐量為 5.8/秒,性能有所提升

是否是線程越多,速度越快呢,在實(shí)際測試中,并不是線程越多性能越高,單靠提升線程數(shù)量是不能一直得到性能提升的。

4.4 設(shè)置nio的運(yùn)行模式

<Connector executor="tomcatThreadPool" port="8000" protocol="org.apache.coyote.http11.Http11Nio2Protocol" connectionTimeout="20000" redirectPort="8443" />

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

可以看到,平均響應(yīng)時間有所縮短,吞吐量有所提升,所以從中可以看出,nio2的性能要高于Nio

4.5 調(diào)整JVM參數(shù)進(jìn)行優(yōu)化

4.5.1 設(shè)置并行垃圾回收器

修改 bin/catalina.sh

JAVA_OPTS="-XX:+UseParallelGC -XX:+UseParallelOldGC -Xms64m -Xmx512m -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:../logs/gc.log"


提高網(wǎng)站訪問性能——Tomcat優(yōu)化

可以看到,平均響應(yīng)時間有所縮短,吞吐量有所提升

五、總結(jié)

今天的tomcat性能不知道大家看的怎么樣,感興趣的小伙伴可以點(diǎn)贊關(guān)注一波,有問題的小伙伴可以在下面留言,看到了會第一時間回復(fù)大家,謝謝,大家加油~

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

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

長按訂閱更多精彩▼

提高網(wǎng)站訪問性能——Tomcat優(yōu)化

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

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

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