<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Rory's Blog
    Happy study,Happy work,Happy life
    posts - 22,  comments - 46,  trackbacks - 0

    ? jspark 的這篇文章《開(kāi)發(fā)階段eclipse下面的spring容器的啟動(dòng)優(yōu)化 》講到如何加快spring的啟動(dòng)速度。非常感謝jspark. 一下是引用的原文:

    ? 最近在負(fù)責(zé)一個(gè)大項(xiàng)目,項(xiàng)目組成員包括項(xiàng)目經(jīng)理大概10個(gè)人左右。項(xiàng)目技術(shù)用struts+spring+hibernate實(shí)現(xiàn)。項(xiàng)目的規(guī)模相對(duì)來(lái)說(shuō)是比較大的,總共有10大模塊,每個(gè)大模塊又分為有十幾個(gè)、甚至幾十個(gè)小模塊。開(kāi)發(fā)工具用eclipse,由于在開(kāi)發(fā)階段,項(xiàng)目開(kāi)發(fā)成員需要頻繁重啟服務(wù)器。在啟動(dòng)服務(wù)器的時(shí)候,每次啟動(dòng)時(shí)間總是會(huì)超過(guò)1分鐘。記得以前在做另外一個(gè)項(xiàng)目時(shí),啟動(dòng)時(shí)間不到5秒鐘,相差了10倍,而且項(xiàng)目規(guī)模是差不多的。

    ??? 從初步分析來(lái)說(shuō),應(yīng)該是hibernate解釋hbm.xml時(shí)花費(fèi)時(shí)間,或者可能是spring容器啟動(dòng)并解釋所有的bean配置文件。診斷了一下,發(fā)現(xiàn)1分鐘消耗的時(shí)間主要分布在hibernate解釋hbm.xml花費(fèi)5秒;spring容器從啟動(dòng)到解釋bean配置文件竟然花了58秒,真是太囂張了。當(dāng)時(shí)非常懷疑spring的效率問(wèn)題。企圖從網(wǎng)上搜索相關(guān)資料,看看有什么優(yōu)化措施。

    ??? 首先是找到了hibernate的啟動(dòng)優(yōu)化 http://www.hibernate.org/194.html? 里面的主要思想是通過(guò)將xml序列花到本地的文件里,每次讀取的時(shí)候根據(jù)情況,從本地文件讀取并反序列化,節(jié)省了hibernate xml的解析時(shí)間。按照這個(gè)方式測(cè)試了一下,發(fā)現(xiàn)hibernate的啟動(dòng)時(shí)間從5秒降低到3秒,但是這個(gè)優(yōu)化對(duì)于整個(gè)啟動(dòng)過(guò)程是杯水車薪的,毫無(wú)用處。

    ??? 沒(méi)辦法,又仔細(xì)查看了spring的資料,終于發(fā)現(xiàn)spring的容器是提供了lazy-load的,即默認(rèn)的缺省設(shè)置是bean沒(méi)有l(wèi)azy- load,該屬性處于false狀態(tài),這樣導(dǎo)致spring在啟動(dòng)過(guò)程導(dǎo)致在啟動(dòng)時(shí)候,會(huì)默認(rèn)加載整個(gè)對(duì)象實(shí)例圖,從初始化ACTION配置、到 service配置到dao配置、乃至到數(shù)據(jù)庫(kù)連接、事務(wù)等等。這么龐大的規(guī)模,難怪spring的啟動(dòng)時(shí)間要花將近1分鐘。嘗試了一下,把beans的 default-lazy-init改為true就,再次啟動(dòng),速度從原來(lái)的55秒,降到8秒鐘!!Great!雖然是非常小一個(gè)改動(dòng),但是影響確實(shí)非常大。一個(gè)項(xiàng)目組10個(gè)人,假若每個(gè)人一天平均需要在eclipse下啟動(dòng)測(cè)試服務(wù)器50次。那么一天項(xiàng)目組需要重啟500次,每次節(jié)省50秒的話,就是 25000秒,將近幾個(gè)小時(shí),差不多一個(gè)工作日,多么可觀的數(shù)字!

    ?? 不過(guò)在運(yùn)行期間第一次點(diǎn)頁(yè)面的時(shí)候,由于spring做了lazy-load,現(xiàn)在就需要啟動(dòng)一部分需要的beans,所以稍微慢2-3秒鐘,但是明顯比等幾十秒要快很多,值得一鑒。

    ??? 以上是針對(duì)開(kāi)發(fā)階段的spring容器啟動(dòng)優(yōu)化,在部署到實(shí)際環(huán)境中,倒是沒(méi)必要設(shè)置為lazy-load。畢竟部署到實(shí)際環(huán)境中不是經(jīng)常的事,每次啟動(dòng)1分鐘倒不是大問(wèn)題。

    我這里要提醒的是不是說(shuō)有的beans都能設(shè)置default-lazy-init成為true.對(duì)于scheduler的bean不能用lazy-init

    < beans? default-lazy-init ="true" >
    ????
    ????
    < bean? class ="org.springframework.scheduling.quartz.SchedulerFactoryBean" >
    ????????
    < property? name ="triggers" >
    ????????????
    < list >
    ????????????????
    < ref? bean ="buildHtmlTrigger" />
    ????????????????
    < ref? bean ="askTrigger" />
    ????????????????
    < ref? bean ="mailSenderTrigger" />
    ????????????????
    < ref? bean ="topicDetailBuildTrigger" />
    ????????????????
    < ref? bean ="forumBuildTrigger" />
    ????????????????
    < ref? bean ="topicBuildTrigger" />
    ????????????
    </ list >
    ????????
    </ property >
    ????
    </ bean >
    </ beans >




    這樣的話。所有的scheduler就都不管用了。所以請(qǐng)大家要注意。

    < beans >
    ????
    ????
    < bean? class ="org.springframework.scheduling.quartz.SchedulerFactoryBean" >
    ????????
    < property? name ="triggers" >
    ????????????
    < list >
    ????????????????
    < ref? bean ="buildHtmlTrigger" />
    ????????????????
    < ref? bean ="askTrigger" />
    ????????????????
    < ref? bean ="mailSenderTrigger" />
    ????????????????
    < ref? bean ="topicDetailBuildTrigger" />
    ????????????????
    < ref? bean ="forumBuildTrigger" />
    ????????????????
    < ref? bean ="topicBuildTrigger" />
    ????????????
    </ list >
    ????????
    </ property >
    ????
    </ bean >
    </ beans >


    ?

    posted on 2006-08-10 10:59 莫多 閱讀(3320) 評(píng)論(2)  編輯  收藏 所屬分類: Spring

    FeedBack:
    # re: 關(guān)于spring啟動(dòng)的優(yōu)化的問(wèn)題
    2006-08-11 20:04 | 綠色使者、綠色心情
    還有一些其它的beans,也不能這樣的,比如datasource好像lazy-load也有問(wèn)題的。  回復(fù)  更多評(píng)論
      
    # re: 關(guān)于spring啟動(dòng)的優(yōu)化的問(wèn)題
    2006-08-11 20:58 | 莫多
    是么。不過(guò)我好像是可以的啊。
    除了。scheduler我好都設(shè)置的lazy-init
      回復(fù)  更多評(píng)論
      

    <2006年8月>
    303112345
    6789101112
    13141516171819
    20212223242526
    272829303112
    3456789

    常用鏈接

    留言簿(1)

    隨筆分類(27)

    隨筆檔案(22)

    Friends

    搜索

    •  

    積分與排名

    • 積分 - 62232
    • 排名 - 845

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 中文字幕无码成人免费视频| 亚洲精品A在线观看| 最近中文字幕无免费| 亚洲一区二区三区免费观看| 四虎免费影院4hu永久免费| 一级特黄录像视频免费| 亚洲一区二区三区高清| 日韩免费视频在线观看| 你是我的城池营垒免费看 | 亚洲熟妇色自偷自拍另类| 国产在线a不卡免费视频| 99re这里有免费视频精品| 国产精品亚洲专区在线播放| 亚洲成AV人片在线观看无| 天天看免费高清影视| 国产真人无码作爱视频免费| 亚洲中文字幕久久精品蜜桃 | 亚洲日本国产精华液| jlzzjlzz亚洲乱熟在线播放| 在线永久看片免费的视频| 人妻18毛片a级毛片免费看| 亚洲天堂福利视频| 亚洲精品无码MV在线观看| 国产精品麻豆免费版| 午夜免费1000部| 拍拍拍无挡免费视频网站| 国产AV无码专区亚洲AV麻豆丫| 91久久亚洲国产成人精品性色 | 亚洲成a人片在线观看老师| 可以免费看黄的网站| 麻豆精品不卡国产免费看| 污污的视频在线免费观看| 久久综合久久综合亚洲| 久久夜色精品国产噜噜亚洲AV| 中文字幕在线亚洲精品| 又粗又大又猛又爽免费视频| 99久久免费国产精品特黄| 无码av免费一区二区三区试看| 国产乱妇高清无乱码免费| 国产成人亚洲毛片| 亚洲日本va一区二区三区 |