tomcat啟動時間很慢

原因:

Tomcat 7/8都使用org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom類產(chǎn)生安全隨機(jī)類SecureRandom的實例作為會話ID缓艳,這里花去了62秒,也即接近1分鐘,當(dāng)然有時花費(fèi)時間更長,達(dá)到5-10分鐘。

SHA1PRNG算法是基于SHA-1算法實現(xiàn)且保密性較強(qiáng)的偽隨機(jī)數(shù)生成器寄锐。

在SHA1PRNG中,有一個種子產(chǎn)生器,它根據(jù)配置執(zhí)行各種操作要尔。

1)如果Java.security.egd 屬性或securerandom.source屬性指定的是”file:/dev/random”或”file:/dev/urandom”,那么JVM 會使用本地種子產(chǎn)生器NativeSeedGenerator新娜,它會調(diào)用super()方法盈电,即調(diào)用 SeedGenerator.URLSeedGenerator(/dev/random)方法進(jìn)行初始化。

2)如果java.security.egd屬性或securerandom.source屬性指定的是其它已存在的URL杯活,那么會調(diào)用SeedGenerator.URLSeedGenerator(url)方法進(jìn)行初始化匆帚。

這就是為什么我們設(shè)置值為”file:///dev/urandom”或者值為”file:/./dev/random”都會起作用的原因。

在這個實現(xiàn)中旁钧,產(chǎn)生器會評估熵池(entropy pool)中的噪聲數(shù)量吸重。隨機(jī)數(shù)是從熵池中進(jìn)行創(chuàng)建的。當(dāng)讀操作時歪今,/dev/random設(shè)備會只返回熵池中噪聲的隨機(jī)字節(jié)嚎幸。/dev/random非 常適合那些需要非常高質(zhì)量隨機(jī)性的場景,比如一次性的支付或生成密鑰的場景寄猩。

當(dāng)熵池為空時嫉晶,來自/dev/random的讀操作將被阻塞,直到熵池收集到足夠的環(huán)境噪聲數(shù)據(jù)田篇。這么做的目的是成為一個密碼安全的偽隨機(jī)數(shù)發(fā)生器替废,熵池要有盡可能大的輸出。對于生成高質(zhì)量的加密密鑰或者是需要長期保護(hù)的場景泊柬,一定要這么做椎镣。

那么什么是環(huán)境噪聲?

隨機(jī)數(shù)產(chǎn)生器會手機(jī)來自設(shè)備驅(qū)動器和其它源的環(huán)境噪聲數(shù)據(jù)兽赁,并放入熵池中状答。產(chǎn)生器會評估熵池中的噪聲數(shù)據(jù)的數(shù)量冷守。當(dāng)熵池為空時,這個噪聲數(shù)據(jù)的收集是比較花時間的惊科。這就意味著拍摇,Tomcat在生產(chǎn)環(huán)境中使用熵池時,會被阻塞較長的時間馆截。

解決:

有兩種解決辦法:

1)在Tomcat環(huán)境中解決

可以通過配置JRE使用非阻塞的Entropy Source授翻。

在catalina.sh中加入這么一行:

JAVA_OPTS="-Djava.security.egd=file:/dev/./urandom"
即可。

加入后再啟動Tomcat孙咪,整個啟動耗時迅速下降堪唐。

2)在JVM環(huán)境中解決

打開$JAVA_PATH/jre/lib/security/java.security這個文件,找到下面的內(nèi)容:

securerandom.source=file:/dev/urandom
替換成

securerandom.source=file:/dev/./urandom

http://www.cnblogs.com/suiyueqiannian/p/6060951.html?utm_source=itdadao&utm_medium=referral

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末翎蹈,一起剝皮案震驚了整個濱河市淮菠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌荤堪,老刑警劉巖合陵,帶你破解...
    沈念sama閱讀 206,013評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異澄阳,居然都是意外死亡拥知,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,205評論 2 382
  • 文/潘曉璐 我一進(jìn)店門碎赢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來低剔,“玉大人,你說我怎么就攤上這事肮塞〗蟪荩” “怎么了?”我有些...
    開封第一講書人閱讀 152,370評論 0 342
  • 文/不壞的土叔 我叫張陵枕赵,是天一觀的道長猜欺。 經(jīng)常有香客問我,道長拷窜,這世上最難降的妖魔是什么开皿? 我笑而不...
    開封第一講書人閱讀 55,168評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮篮昧,結(jié)果婚禮上赋荆,老公的妹妹穿的比我還像新娘。我一直安慰自己恋谭,他們只是感情好糠睡,可當(dāng)我...
    茶點故事閱讀 64,153評論 5 371
  • 文/花漫 我一把揭開白布挽鞠。 她就那樣靜靜地躺著疚颊,像睡著了一般狈孔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上材义,一...
    開封第一講書人閱讀 48,954評論 1 283
  • 那天均抽,我揣著相機(jī)與錄音,去河邊找鬼其掂。 笑死油挥,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的款熬。 我是一名探鬼主播深寥,決...
    沈念sama閱讀 38,271評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼贤牛!你這毒婦竟也來了惋鹅?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,916評論 0 259
  • 序言:老撾萬榮一對情侶失蹤殉簸,失蹤者是張志新(化名)和其女友劉穎闰集,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體般卑,經(jīng)...
    沈念sama閱讀 43,382評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡武鲁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,877評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了蝠检。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沐鼠。...
    茶點故事閱讀 37,989評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖叹谁,靈堂內(nèi)的尸體忽然破棺而出迟杂,到底是詐尸還是另有隱情,我是刑警寧澤本慕,帶...
    沈念sama閱讀 33,624評論 4 322
  • 正文 年R本政府宣布排拷,位于F島的核電站,受9級特大地震影響锅尘,放射性物質(zhì)發(fā)生泄漏监氢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,209評論 3 307
  • 文/蒙蒙 一藤违、第九天 我趴在偏房一處隱蔽的房頂上張望浪腐。 院中可真熱鬧,春花似錦顿乒、人聲如沸议街。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,199評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽特漩。三九已至吧雹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間涂身,已是汗流浹背雄卷。 一陣腳步聲響...
    開封第一講書人閱讀 31,418評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留蛤售,地道東北人丁鹉。 一個月前我還...
    沈念sama閱讀 45,401評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像悴能,于是被迫代替她去往敵國和親揣钦。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,700評論 2 345

推薦閱讀更多精彩內(nèi)容