Springboot Tomcat APR模式詳解和實踐記錄
前面的文章講解了tomcat的nio線程模型,nio也是我們?nèi)粘S玫谋容^多的io模式,nio對比bio的優(yōu)勢這里就不多說了,網(wǎng)上有很多的文章說的很詳細(xì),今天在文中主要介紹下tomcat的apr模式,apr全稱為apache portable runtime,這里套用下wiki對apr的解釋:
很好理解就是為apache server準(zhǔn)備的一套基于操作系統(tǒng)底層的類庫。
這里先說下tomcat從nio切換到apr模式后的性能提升,使用的是公司的4c 8g的pc server,并發(fā)400的情況下的壓測數(shù)據(jù),我這里的性能提升沒有很多網(wǎng)友說的那么大,有的網(wǎng)友甚至達(dá)到了80%的性能提升,我來回測了好幾輪大約提升20%左右,壓測的項目tps從原來的1500提升到了最高1800左右,對于這個結(jié)果還是比較滿意的,在不改動業(yè)務(wù)邏輯代碼的情況下能夠達(dá)到這個指標(biāo)。
APR的整體模式還是非阻塞IO,實現(xiàn)的線程模型也是按照NIO的標(biāo)準(zhǔn)模型實現(xiàn)的,從官方文檔(http://apr.apache.org/docs/apr/1.6/modules.html)可以看到APR根據(jù)不同操作系統(tǒng),分別用c重寫了大部分IO和系統(tǒng)線程操作模塊,這就是為什么APR在不改動代碼的情況下能夠提升,具體原理可以參考下我寫的Tomcat NIO線程模式這篇文章。
下面這些就是APR重寫的模塊:
在Springboot中內(nèi)嵌的Tomcat默認(rèn)啟動開啟的是NIO模式,這里如果我們要在linux內(nèi)核的系統(tǒng)上使用APR模式,那么需要安裝一些lib庫,可以通過rpm -q | grep apr
來查看是否安裝了apr,如果安裝了則不再需要安裝,如果未安裝則需要安裝下列庫:
1)openssl,需要版本大于1.0.2,如果不使用https openssl也可以不安裝,就是在啟動的時候會報openssl的錯誤,直接忽視就可以了;
2)apr,可以去官網(wǎng)下載1.6.2最新版進(jìn)行下載 http://apr.apache.org/download.cgi
apr-util,在同一個頁面進(jìn)行下載,最新版本為1.6.0版本
apr-iconv,在同一個頁面進(jìn)行下載,最新版本為1.2.1版本
tomcat-native,在tomcat中自帶了安裝包,可以在tomcat的bin目錄下找到tomcat-native.tar;
安裝apr
下載apr安裝包apr-1.6.2.tar.gz
tar -xvf apr-1.6.2.tar.gz cd apr-1.6.2
./configure 檢查是否符合安裝條件并配置安裝參數(shù),檢查是否缺失類庫,一般來說如果安裝的不是精簡版系統(tǒng)都是能順利通過的
make & make install
如果不設(shè)置安裝路徑,那么系統(tǒng)默認(rèn)的安裝路徑為/usr/local/apr/lib
安裝apr-util
下載apr-util安裝包apr-util-1.6.0.tar.gz
tar -xvf apr-util-1.6.0.tar.gz cd apr-util-1.6.0 ./configure --with-apr=/usr/local/apr/lib --with-java-home=/usr/lib/jvm/jdk-8u144-linux-x64/jdk1.8.0_144 安裝apr-util需要配置apr路徑和jvm路徑,否則會報錯找不到apr make & make install
安裝apr-iconv
下載apr-iconv.tar.gz
tar -xvf apr-iconv.tar.gz cd apr-iconv ./configure --with-apr=/usr/local/apr/lib --with-java-home=/usr/lib/jvm/jdk-8u144-linux-x64/jdk1.8.0_144 make & make install
安裝tomcat-native
cd tomcat/bin tar -xvf tomcat-native cd tomcat-native ./configure --with-apr=/usr/local/apr/lib --with-java-home=/usr/lib/jvm/jdk-8u144-linux-x64/jdk1.8.0_144 make & make install
到此安裝工作就全部完成了,如果要查看本機(jī)安裝的java路徑可以通過which java查看
配置apr
vi /etc/profile
在profile最前面加上 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/apr-1.6.2/lib
命令行輸入 source /etc/profile 使之生效
新增APRConfig類
網(wǎng)上大部分講解配置tomcat apr的文章,都只是講了如何在獨立tomcat服務(wù)上如何配置apr,只需要修改server.xml中的connnector 的protocol就可以了,對于springboot會稍微復(fù)雜些,需要增加一個apr配置類在啟動的時候修改Embed的tomcat connector網(wǎng)絡(luò)接入?yún)f(xié)議。
啟動springboot
本以為這樣做完后可以直接啟動springboot打開apr模式了,可是啟動會發(fā)現(xiàn)報錯,而且這個錯誤會讓你很費解,看錯誤提示報的應(yīng)該是服務(wù)啟動端口被占用,但是實際查下來這個只是表面現(xiàn)象不是根本原因。
打開debug后查看系統(tǒng)日志發(fā)現(xiàn)真正的原因是系統(tǒng)找不到apr的lib庫。
看到這個錯誤提示一下子豁然開朗,趕緊在啟動參數(shù)中加上apr的路徑,重新啟動。
啟動成功后看到日志中打出了以下內(nèi)容,則表示apr模式啟動成功,開始享受APR帶來的飛速感受吧。
源碼demo git下載地址:https://github.com/feiweiwei/springcloud-sample.git
到此這篇關(guān)于Springboot Tomcat APR模式詳解和實踐的文章就介紹到這了,更多相關(guān)Springboot Tomcat APR模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot快速構(gòu)建應(yīng)用程序方法介紹
這篇文章主要介紹了SpringBoot快速構(gòu)建應(yīng)用程序方法介紹,涉及SpringBoot默認(rèn)的錯誤頁面,嵌入式Web容器層面的約定和定制等相關(guān)內(nèi)容,具有一定借鑒價值,需要的朋友可以參考下。2017-11-11Java服務(wù)調(diào)用失敗報Service com.oneinfinite.adflow.api.service.T
在Java開發(fā)中,服務(wù)調(diào)用是常見的操作,尤其是在微服務(wù)架構(gòu)中,然而,服務(wù)調(diào)用過程中可能會遇到各種問題,下面我們來看看如何解決Service com.oneinfinite.adflow.api.service.TestService with version 0.0.0 not found的問題吧2025-03-03實現(xiàn)Servlet程序的三種方法(小結(jié))
這篇文章主要介紹了實現(xiàn)Servlet程序的三種方法(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01java實現(xiàn)的根據(jù)概率隨機(jī)中獎測試類
這篇文章主要介紹了java實現(xiàn)的根據(jù)概率隨機(jī)中獎測試類,結(jié)合完整實例形式詳細(xì)分析了java隨機(jī)數(shù)實現(xiàn)概率運算相關(guān)操作技巧,需要的朋友可以參考下2019-09-09MyBatis-Plus實現(xiàn)字段自動填充功能的示例
本文主要介紹了MyBatis-Plus實現(xiàn)字段自動填充功能的示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11Java實現(xiàn)將String轉(zhuǎn)化為Int
這篇文章主要介紹了Java實現(xiàn)將String轉(zhuǎn)化為Int方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05