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

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

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

    posts - 36, comments - 419, trackbacks - 0, articles - 0
      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
         本篇文章主要討論下目前JS,CSS 合并、壓縮、緩存管理存在的一些問(wèn)題,然后分享下自己項(xiàng)目中用到的1個(gè)處理方案,并提供1個(gè)實(shí)例下載。

    存在的問(wèn)題:    
     
         合并、壓縮文件主要有2方面的問(wèn)題:
           1. 每次發(fā)布的時(shí)候需要運(yùn)行一下自己寫的bat文件或者其他程序把文件按照自己的配置合并和壓縮。
     
           2. 因生產(chǎn)環(huán)境和開發(fā)環(huán)境需要加載的文件不一樣,生產(chǎn)環(huán)境為了需要加載合并、壓縮后的文件,而開發(fā)環(huán)境為了修改、調(diào)試方便,需要加載非合并、壓縮的文件,所以我們常常需要在JSP中類似與下面的判斷代碼:
    <c:if test="${env=='prod'}">
       <script type="text/javascript" src="/js/all.js"></script>
    </c:if>
    <c:if test="${env=='dev'}">
       <script type="text/javascript" src="/js/1.js"></script>
       <script type="text/javascript" src="/js/2.js"></script>
       <script type="text/javascript" src="/js/3.js"></script>
    </c:if>
         
        緩存問(wèn)題:在現(xiàn)在JS滿天飛的時(shí)代,大家都知道緩存能帶來(lái)的巨大好處,但緩存確實(shí)非常麻煩的一個(gè)問(wèn)題,相信很多人曾經(jīng)歷過(guò)下面的情況:為了讓程序更快,在服務(wù)器上為JS加上緩沖5天的代碼,但產(chǎn)品更新后第二天就接到電話說(shuō)系統(tǒng)出錯(cuò),詳細(xì)了解后就發(fā)現(xiàn)是緩存引起的,讓用戶刪除緩存后就會(huì)OK。原因很簡(jiǎn)單,就是你JS已經(jīng)修改了,但用戶還在使用緩存中的老JS。在經(jīng)歷幾次這種情況,被領(lǐng)導(dǎo)數(shù)落了幾次后。沒(méi)辦法只能把JS的緩沖去掉,或者改成8個(gè)小時(shí)。可這樣就完全失去了緩存的優(yōu)勢(shì)了,哪我們到底需要解決哪些問(wèn)題才能讓我們使用緩沖順心如意了?
        1. 如何在修改了某個(gè)JS后,自動(dòng)把所有引用該JS頁(yè)面的代碼中加上1個(gè)版本號(hào)?

        2. 該如何生成版本號(hào),根據(jù)什么來(lái)產(chǎn)生這個(gè)版本號(hào)。

        可能有人為了解決上面的緩存問(wèn)題,寫了個(gè)JSP標(biāo)簽,通過(guò)標(biāo)簽讀取JS、css文件的修改時(shí)間來(lái)作為版本號(hào),從而來(lái)解決上面2個(gè)問(wèn)題。但這種方法有下面幾個(gè)缺點(diǎn):
        1. 每次請(qǐng)求都要通過(guò)標(biāo)簽讀取讀取文件的修改時(shí)間,速度慢。當(dāng)然你可以把文件的修改時(shí)間放到緩存中,這樣也會(huì)加到了內(nèi)存使用量。

        2. 在HTML靜態(tài)頁(yè)面中用不了

        3. 如果你們公司是如下的部署發(fā)布方式(我們公司就是這樣),則會(huì)失效。每次發(fā)布,不是直接覆蓋之前的WEB目錄,運(yùn)維的為的發(fā)布方便,要求每次發(fā)布直接給他們1個(gè)war包,他們會(huì)把之前WEB目錄整個(gè)刪除,然后上傳現(xiàn)在的war包,這樣就導(dǎo)致程序運(yùn)行后,所有文件的最后修改時(shí)間都是解壓war的時(shí)間。


    分享自己項(xiàng)目中的處理方案:
          
        為了解決上面討論過(guò)的問(wèn)題,在下寫了1個(gè)如下的組件,組件中根據(jù)我們自己的實(shí)際情況使用了文件大小來(lái)做為文件的版本號(hào),雖然在文件修改很小(比如把字符a改成b),可能文件大小并沒(méi)有變,導(dǎo)致版本號(hào)也不會(huì)變。

    但這種機(jī)率還是非常低的。當(dāng)然如果你覺的使用文件修改時(shí)間作為版本號(hào)適合你,只需要修改一行代碼就行,下面看下這個(gè)組件的處理流程(本來(lái)想用流程圖表達(dá),最后還是覺的文字來(lái)的直白寫):

        1. 程序啟動(dòng)(contextInitialized)
     
        2. 搜索程序目錄下的所有merge.txt文件,根據(jù)merge.txt文件的配置合并文件, merge.txt文件實(shí)例如下:
    # 文件合并配置文件,多個(gè)文件以|隔開,以/開頭的表示從根目錄開始, 
    # 空格之后的文件名表示合并之后的文件名

    # 把1,2,3合并到all文件中
    1.js|2.js|3.js all.js

    #合并CSS
    /css/mian.css|/css/common.css all.css

        3. 搜索程序目錄下所有JS,CSS文件(包括合并后的),每個(gè)文件都?jí)嚎s后生成對(duì)應(yīng)的1個(gè)新文件。


        4. 搜索程序目錄下所有JSP,html文件,把所有JS,css的引用代碼改成壓縮后并加了版本號(hào)的引用。

    實(shí)例:

        實(shí)例的文件結(jié)構(gòu)如下圖:
        
        
        看JSP原始代碼(程序運(yùn)行前):
    <%@page contentType="text/html" pageEncoding="UTF-8"%>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"  "http://www.w3.org/TR/html4/loose.dtd">
    <% boolean isDev = false;  // 是否開發(fā)環(huán)境%>
    <html>
        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
            <title>JSP Page</title>
            <% if(isDev){ %>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2.js"></script>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/1.js"></script>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/2.js"></script>
            <link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/1.css" />
            <link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/2.css" />
            <% }else{ %>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2.js"></script>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/all.js"></script>
            <link type="text/css" rel="stylesheet"  href="<%=request.getContextPath() %>/css/all.css" />
            <% } %>
        </head>
        <body>
            <h1 class="c1">Hello World!</h1>
        </body>
    </html>


        程序運(yùn)行后JSP的代碼:
    <%@page contentType="text/html" pageEncoding="UTF-8"%>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <%
        boolean isDev = false;  // 是否開發(fā)環(huán)境
    %>
    <html>
        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
            <title>JSP Page</title>
            <% if(isDev){ %>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2-3gmin.js?99375"></script>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/1-3gmin.js?90"></script>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/2-3gmin.js?91"></script>
            <link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/1-3gmin.css?35" />
            <link type="text/css" rel="stylesheet" href="<%=request.getContextPath() %>/css/2-3gmin.css?18" />
            <% }else{ %>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery-1.4.2-3gmin.js?99375"></script>
            <script type="text/javascript" src="<%=request.getContextPath() %>/js/all-3gmin.js?180"></script>
            <link type="text/css" rel="stylesheet"  href="<%=request.getContextPath() %>/css/all-3gmin.css?53" />
            <% } %>
        </head>
        <body>
            <h1 class="c1">Hello World!</h1>
        </body>
    </html>

        加3gmin后綴的文件全部是程序啟動(dòng)時(shí)自動(dòng)生成的。

    實(shí)例下載:猛擊此處下載

    PS:自己的設(shè)計(jì)的處理方案并沒(méi)有解決"需要JSP中加判斷代碼的問(wèn)題",主要是因?yàn)檫€沒(méi)有找到什么好的辦法去自動(dòng)刪除1.js,2.js,3.js的3個(gè)引用,而插入1個(gè)新的all.js的引用,如果那位同學(xué)對(duì)解決這個(gè)問(wèn)題有好的想法,請(qǐng)不吝賜教。
          如果有同學(xué)想使用這個(gè)組件,建議在測(cè)試環(huán)境下運(yùn)行一次后,把修改后的程序直接上傳到正式服務(wù)器上,然后去掉這個(gè)功能,不然在服務(wù)器上每次啟動(dòng)都調(diào)用這個(gè)功能還是需要花費(fèi)一些時(shí)間和資源的 
           其實(shí)一直想使用SVN中的版本號(hào)來(lái)控制緩存,這個(gè)是最嚴(yán)謹(jǐn)?shù)囊粋€(gè)方法,但也因?yàn)樽銎饋?lái)太復(fù)雜,所以一直也沒(méi)做起來(lái),以后以后有時(shí)間可以再研究。

        有需要請(qǐng)查看:高性能WEB開發(fā)系列


    [作者]:BearRui(AK-47)
    [博客]: http://www.tkk7.com/bearrui/
    [聲明]:本博所有文章版權(quán)歸作者所有(除特殊說(shuō)明以外),轉(zhuǎn)載請(qǐng)注明出處.
    英雄,別走啊,幫哥評(píng)論下:  

    精彩推薦 好文要頂 水平一般 看不懂 還需努力

    評(píng)論

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-06-09 15:49 by panasia
    這個(gè)問(wèn)題,我在csdn上問(wèn)過(guò)。。到現(xiàn)在還是無(wú)人問(wèn)津。。。當(dāng)初我也是考慮用svn的版本號(hào)來(lái)解決這個(gè)問(wèn)題。不過(guò)個(gè)人能力有限。。。。現(xiàn)在還未解決。

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-06-09 15:53 by panasia
    我們現(xiàn)在也碰到相同的問(wèn)題。。。css,js經(jīng)常性更新。。客戶端如果有緩存。。就讀不到最新的內(nèi)容。。如果用js加當(dāng)前時(shí)間來(lái)判斷。。每次客戶端都要下載。就不能緩存了。我想這個(gè)最好的辦法也只有用svn版本號(hào)來(lái)控制。。

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-06-09 15:56 by BearRui(AK-47)
    用SVN版本比較麻煩,目前我們用文件大小來(lái)做版本號(hào)幾乎不會(huì)再碰見緩存的問(wèn)題了,感覺這種方法比較簡(jiǎn)單易用。

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理[未登錄](méi)  回復(fù)  更多評(píng)論   

    2010-06-17 00:05 by Charles
    這個(gè)問(wèn)題確實(shí)很惡心啊,有一種做法就是用一個(gè)腳本去讀取所有文件的修改時(shí)間,你文中也提了,這種是自動(dòng)化程度最高的一個(gè)做法,但是這種最麻煩的就是每次載入頁(yè)面,都要去讀取磁盤,這在訪問(wèn)量大的時(shí)候,可能會(huì)帶來(lái)瓶頸,另一個(gè)問(wèn)題就是文件修改時(shí)間確實(shí)也不算準(zhǔn)。

    我現(xiàn)在想做的一個(gè)方案就是半自動(dòng)化的,基本上是通過(guò)使用部署腳本,每次部署的時(shí)候,執(zhí)行一次,也即沒(méi)部署一次,就執(zhí)行一次文件歸并。但是沒(méi)有了自動(dòng)化,也很無(wú)聊。

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-06-17 08:49 by BearRui(AK-47)
    不需要每次載入頁(yè)面的時(shí)候去讀取文件屬性,使用我文中的代碼,在程序啟動(dòng)的時(shí)候執(zhí)行一次就可以,算是自動(dòng)化的。

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-06-24 11:56 by ed hardy
    軟件類的知識(shí)太深?yuàn)W了,看懂它要有一段時(shí)間嘍!

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理[未登錄](méi)  回復(fù)  更多評(píng)論   

    2010-08-10 11:02 by Allen
    我們的思路是:部署兩個(gè)war,一個(gè)war專門負(fù)責(zé)導(dǎo)航(其web-context不能修改,終端用戶使用此作為入口登錄),另一個(gè)war是真正的應(yīng)用部署,每次從新部署,修改其web-context,這樣web資源自然會(huì)從新下載。

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-08-10 11:04 by BearRui(AK-47)
    @Allen
    哪你這樣是不是不每次重新部署,所有WEB資源都重新下載,而不是只下載修改了的文件?

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-11-17 15:52 by study
    版本號(hào)用MD5生成有啥害處么?

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2010-11-17 15:55 by BearRui(AK-47)
    @study
    MD5 好處在哪了?除了每次MD5消耗性能外

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2011-03-08 12:06 by 路過(guò)
    @panasia
    可以用文件的最后一次修改時(shí)間,來(lái)設(shè)置 Last-Modified

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2012-09-05 13:14 by dohkoos
    [quote]因生產(chǎn)環(huán)境和開發(fā)環(huán)境需要加載的文件不一樣,生產(chǎn)環(huán)境為了需要加載合并、壓縮后的文件,而開發(fā)環(huán)境為了修改、調(diào)試方便,需要加載非合并、壓縮的文件,所以我們常常需要在JSP中類似與下面的判斷代碼。[/quote]

    這個(gè)是開發(fā)流程的問(wèn)題。設(shè)置兩個(gè)分支,prod和dev,分別使用不同的配置文件,在發(fā)布的時(shí)候打包就可以了。

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2014-06-26 11:27 by newobj
    第二個(gè)jar包的源碼能否分享下.
    還有替換jsp,html,js 中應(yīng)用的腳本JsCssReplace中的replace方法還是不要替換的為好,因?yàn)槿绻闷渌W(wǎng)站上的腳本,也會(huì)自動(dòng)加上-3gmin,就會(huì)找不到文件的.

    # re: 高性能WEB開發(fā)(7) - JS、CSS的合并、壓縮、緩存管理  回復(fù)  更多評(píng)論   

    2014-08-17 01:01 by andrei
    可以考慮SSI服務(wù)端包含,把JavaScript的引用(包含時(shí)間戳,版本)寫在SSI的文件中,到時(shí)候發(fā)布只發(fā)布SSI包含的文件就行了,然后環(huán)境分離的問(wèn)題也迎刃而解。
    主站蜘蛛池模板: 亚洲AV无码之日韩精品| 久久国产亚洲精品| 免费a级毛片无码av| 性xxxxx大片免费视频| EEUSS影院WWW在线观看免费| 亚洲精品无码mⅴ在线观看| 亚洲天堂中文资源| 亚洲啪啪AV无码片| 亚洲国产婷婷综合在线精品| 成年美女黄网站色大免费视频| 亚欧免费一级毛片| 三级黄色免费观看| 一级毛片成人免费看a| 亚洲av无一区二区三区| 亚洲最大成人网色香蕉| 亚洲理论片在线中文字幕| 久久久亚洲欧洲日产国码二区| 亚洲精品乱码久久久久久自慰| 亚洲精品国产高清不卡在线| 在线观着免费观看国产黄| 成人毛片18岁女人毛片免费看| 99视频全部免费精品全部四虎| 2021在线观看视频精品免费| 99免费观看视频| 1000部免费啪啪十八未年禁止观看| 日韩视频免费在线观看| 两个人看的www免费| 两个人看的www免费视频中文| 国产男女爽爽爽免费视频| 免费人成动漫在线播放r18 | 国产精品高清免费网站 | 亚洲国产精品人人做人人爱| 国产三级免费电影| 国产免费av片在线无码免费看| 国产又长又粗又爽免费视频 | 亚洲国产欧美一区二区三区| 国内精品久久久久影院亚洲 | 大地资源在线观看免费高清| 成人A级毛片免费观看AV网站| 成年美女黄网站18禁免费| 美女被免费视频网站a国产|