小編給大家分享一下Tomcat在Linux服務(wù)器上BIO、NIO、APR模式如何設(shè)置,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
站在用戶(hù)的角度思考問(wèn)題,與客戶(hù)深入溝通,找到永年網(wǎng)站設(shè)計(jì)與永年網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶(hù)體驗(yàn)好的作品,建站類(lèi)型包括:網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊(cè)、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋永年地區(qū)。
一、BIO、NIO、AIO
先了解四個(gè)概念:
同步 : 自己親自出馬持銀行卡到銀行取錢(qián)(使用同步IO時(shí),Java自己處理IO讀寫(xiě))。
異步 : 委托一小弟拿銀行卡到銀行取錢(qián),然后給你(使用異步IO時(shí),Java將IO讀寫(xiě)委托給OS處理,需要將數(shù)據(jù)緩沖區(qū)地址和大小傳給OS(銀行卡和密碼),OS需要支持異步IO操作API)。
阻塞 : ATM排隊(duì)取款,你只能等待(使用阻塞IO時(shí),Java調(diào)用會(huì)一直阻塞到讀寫(xiě)完成才返回)。
非阻塞 : 柜臺(tái)取款,取個(gè)號(hào),然后坐在椅子上做其它事,等號(hào)廣播會(huì)通知你辦理,沒(méi)到號(hào)你就不能去,你可以不斷問(wèn)大堂經(jīng)理排到了沒(méi)有,大堂經(jīng)理如果說(shuō)還沒(méi)到你就不能去(使用非阻塞IO時(shí),如果不能讀寫(xiě)Java調(diào)用會(huì)馬上返回,當(dāng)IO事件分發(fā)器會(huì)通知可讀寫(xiě)時(shí)再繼續(xù)進(jìn)行讀寫(xiě),不斷循環(huán)直到讀寫(xiě)完成)。
Java對(duì)BIO、NIO、AIO的支持:
Java BIO : 同步并阻塞,服務(wù)器實(shí)現(xiàn)模式為一個(gè)連接一個(gè)線程,即客戶(hù)端有連接請(qǐng)求時(shí)服務(wù)器端就需要啟動(dòng)一個(gè)線程進(jìn)行處理,如果這個(gè)連接不做任何事情會(huì)造成不必要的線程開(kāi)銷(xiāo),當(dāng)然可以通過(guò)線程池機(jī)制改善。
Java NIO : 同步非阻塞,服務(wù)器實(shí)現(xiàn)模式為一個(gè)請(qǐng)求一個(gè)線程,即客戶(hù)端發(fā)送的連接請(qǐng)求都會(huì)注冊(cè)到多路復(fù)用器上,多路復(fù)用器輪詢(xún)到連接有I/O請(qǐng)求時(shí)才啟動(dòng)一個(gè)線程進(jìn)行處理。
Java AIO(NIO.2) : 異步非阻塞,服務(wù)器實(shí)現(xiàn)模式為一個(gè)有效請(qǐng)求一個(gè)線程,客戶(hù)端的I/O請(qǐng)求都是由OS先完成了再通知服務(wù)器應(yīng)用去啟動(dòng)線程進(jìn)行處理
BIO、NIO、AIO適用場(chǎng)景分析:
BIO方式適用于連接數(shù)目比較小且固定的架構(gòu),這種方式對(duì)服務(wù)器資源要求比較高,并發(fā)局限于應(yīng)用中,JDK1.4以前的唯一選擇,但程序直觀簡(jiǎn)單易理解。
NIO方式適用于連接數(shù)目多且連接比較短(輕操作)的架構(gòu),比如聊天服務(wù)器,并發(fā)局限于應(yīng)用中,編程比較復(fù)雜,JDK1.4開(kāi)始支持。
AIO方式使用于連接數(shù)目多且連接比較長(zhǎng)(重操作)的架構(gòu),比如相冊(cè)服務(wù)器,充分調(diào)用OS參與并發(fā)操作,編程比較復(fù)雜,JDK7開(kāi)始支持。
二、tomcat三種模式簡(jiǎn)介
BIO
BIO(blocking I/O),顧名思義,即阻塞式I/O操作,表示Tomcat使用的是傳統(tǒng)的Java I/O操作(即java.io包及其子包)。
Tomcat在默認(rèn)情況下,就是以bio模式運(yùn)行的。遺憾的是,就一般而言,bio模式是三種運(yùn)行模式中性能最低的一種。我們可以通過(guò)Tomcat Manager來(lái)查看服務(wù)器的當(dāng)前狀態(tài)。
NIO
是Java SE 1.4及后續(xù)版本提供的一種新的I/O操作方式(即java.nio包及其子包)。Java nio是一個(gè)基于緩沖區(qū)、并能提供非阻塞I/O操作的Java API,因此nio也被看成是non-blocking I/O的縮寫(xiě)。它擁有比傳統(tǒng)I/O操作(bio)更好的并發(fā)運(yùn)行性能。
APR
(Apache Portable Runtime/Apache可移植運(yùn)行庫(kù)),是Apache HTTP服務(wù)器的支持庫(kù)。你可以簡(jiǎn)單地理解為,Tomcat將以JNI的形式調(diào)用Apache HTTP服務(wù)器的核心動(dòng)態(tài)鏈接庫(kù)來(lái)處理文件讀取或網(wǎng)絡(luò)傳輸操作,從而大大地提高Tomcat對(duì)靜態(tài)文件的處理性能。 Tomcat apr也是在Tomcat上運(yùn)行高并發(fā)應(yīng)用的首選模式。
三、tomcat三種模式性能比較
這里我引用了網(wǎng)友給出的測(cè)試結(jié)果
四、tomcat模式設(shè)置
我這里演示的是tomcat7,默認(rèn)是BIO模式的。而tomcat8是默認(rèn)NIO模式的。
在這之前,我們先把tomcat管理界面配置起來(lái),以便等下能更方便的觀察我們的bio、nio、apr 模式(如果不想設(shè)置這個(gè),也可以一會(huì)查看tomcat的日志文件)
拉到最下面,復(fù)制紅色框里的內(nèi)容,在注釋外粘貼,添加manager/status用戶(hù)(這里的用戶(hù)名請(qǐng)不要改,改了好像就不行了)
配置完重啟tomcat,通過(guò)ip:port/manager/status 就可以看tomcat狀態(tài)了,里面有服務(wù)器的信息及tomcat信息。
下來(lái)就是三種模式的配置步驟:BIO模式
tomcat7默認(rèn)就是。如果你是tomcat8或9想設(shè)置成BIO模式的,那么在這里修改
找到port=8080端口設(shè)置那項(xiàng),只要紅框內(nèi)是這樣的,重啟tomcat就會(huì)使用BIO模式。tomcat7默認(rèn)就是這個(gè)樣子
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />
NIO模式
在和設(shè)置BIO模式同樣的位置上,將紅框的內(nèi)容變成這樣,重啟tomcat就會(huì)使用NIO模式。tomcat8默認(rèn)就是這個(gè)樣子
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" connectionTimeout="20000" redirectPort="8443" />
APR模式
啟用這種模式稍微麻煩一些,需要安裝一些依賴(lài)庫(kù),以下就是安裝所需的條件:
1,最新的apr
2,最新的apr-util
3,tomcat-native.tar.gz(在tomcat/bin/下有相應(yīng)的安裝tar包)
不過(guò)也需要改配置文件,先來(lái)改配置文件吧,還是在同樣的位置,將紅框的內(nèi)容變成這樣(注意和NIO模式很像),保存退出,然后去安裝依賴(lài)庫(kù)
<Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol" connectionTimeout="20000" redirectPort="8443" />
安裝那三個(gè)依賴(lài)前,先看下服務(wù)器中有沒(méi)有裝apr
我這里是裝過(guò)了(好像是tomcat自己裝的,不記得了),所以要先卸載,忽略依賴(lài)的卸載,重新裝最新的
1.apr(http://apr.apache.org/download.cgi),上傳解壓
安裝到/usr/local/apr
./configure --prefix=/usr/local/apr && make && make install
2.apr-util(http://apr.apache.org/download.cgi),上傳解壓
安裝到/usr/local/apr-util,指定apr的目錄
./configure --with-apr=/usr/local/apr/ --prefix=/usr/local/apr-util && make && make install
3.tomcat-native(在tomcat/bin/下有相應(yīng)的安裝tar包),解壓
安裝,指定apr的目錄和JAVA_HOME的目錄
./tomcat-native-1.2.14-src/native/configure --with-apr=/usr/local/apr --with-java-home=/usr/share/jdk1.8 && make && make install
安裝完后記得在 /etc/profile 文件中的JAVA_HOME環(huán)境變量后面多加一條APR的環(huán)境變量(注意你自己安裝的apr目錄)
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/apr/lib
用source /etc/profile命令讓環(huán)境變量配置立即生效
啟動(dòng)tomcat,訪問(wèn)(你tomcat所在服務(wù)器的ip)192.168.25.128:8080/manager/status,這樣就ok了
如果上面你不想設(shè)置tomcat管理界面,也可以通過(guò)日志查看
看完了這篇文章,相信你對(duì)“Tomcat在Linux服務(wù)器上BIO、NIO、APR模式如何設(shè)置”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)站名稱(chēng):Tomcat在Linux服務(wù)器上BIO、NIO、APR模式如何設(shè)置
網(wǎng)頁(yè)地址:http://chinadenli.net/article44/giooee.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶(hù)體驗(yàn)、App設(shè)計(jì)、品牌網(wǎng)站設(shè)計(jì)、全網(wǎng)營(yíng)銷(xiāo)推廣、微信小程序、Google
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)