<ul id="g60s4"><pre id="g60s4"></pre></ul>
<strong id="g60s4"><nav id="g60s4"></nav></strong>
<ul id="g60s4"></ul>
  • <tr id="g60s4"></tr>
  • 
    
  • 或者

    IIS啟用Gzip壓縮(HTTP壓縮)過程詳解

    作者:黑貓警長 瀏覽:50 發布時間:2017-08-14
    分享 評論 0

    一.摘要

      本文總結了如何為使用IIS托管的網站啟用Gzip壓縮, 從而減少網頁網絡傳輸大小, 提高用戶顯示頁面的速度.

      二.前言.

      本文的知識點是從互聯網收集整理, 主要來源于中文wiki. 使用YSlow檢測網站啟用了哪些優化時, Gzip是十分關鍵的一項. 啟動Gip壓縮將立竿見影的減少頁面的網絡傳輸大小.

      三.HTTP壓縮概述

      HTTP壓縮是在Web服務器和瀏覽器間傳輸壓縮文本內容的方法。HTTP壓縮采用通用的壓縮算法如gzip等壓縮HTML、JavaScript或CSS文件。壓縮的最大好處就是降低了網絡傳輸的數據量,從而提高客戶端瀏覽器的訪問速度。當然,同時也會增加一點點服務器的負擔。Gzip是比較常見的一種HTTP壓縮算法。

      四.HTTP壓縮工作原理

      Web服務器處理HTTP壓縮的工作原理如下:

      1.Web服務器接收到瀏覽器的HTTP請求后,檢查瀏覽器是否支持HTTP壓縮;

      在用戶瀏覽器發送請求的HTTP頭中, 帶有"Accept-Encoding: gzip, deflate"參數則表明支持gzip和deflate兩種壓縮算法.

      2.如果瀏覽器支持HTTP壓縮,Web服務器檢查請求文件的后綴名;

      靜態文件和動態文件后綴啟動要所都需要在MetaBase.xml中設置.

      靜態文件需要設置: HcFileExtensions Metabase Property (單擊跳轉到MSDN說明)

      動態文件需要設置: HcScriptFileExtensions Metabase Property (單擊跳轉到MSDN說明)

      3.如果請求文件是HTML、CSS等靜態文件并且文件后綴啟用了壓縮,則Web服務器到壓縮緩沖目錄中檢查是否已經存在請求文件的最新壓縮文件;

      4.如果請求文件的壓縮文件不存在,Web服務器向瀏覽器返回未壓縮的請求文件,并在壓縮緩沖目錄中存放請求文件的壓縮文件;

      5.如果請求文件的最新壓縮文件已經存在,則直接返回請求文件的壓縮文件;

      6.如果請求文件是ASPX等動態文件并且文件后綴啟用了壓縮,Web服務器動態壓縮內容并返回瀏覽器,壓縮內容不存放到壓縮緩存目錄中。

      五. 在IIS中啟用HTTP壓縮

      IIS默認并不支持HTTP壓縮,需要進行簡單的配置

      1.打開Internet信息服務(IIS)管理器,右擊"網站"->"屬性",選擇"服務"。在"HTTP壓縮"框中選中"壓縮應用程序文件"和"壓縮靜態文件",按需要設置"臨時目錄"和"臨時目錄的最大限制";

      image

      2.提醒: 經試驗此步驟在本人機器上沒有作用, 可以忽略.

      在Internet信息服務(IIS)管理器,右擊"Web服務擴展"->"增加一個新的Web服務擴展...",在"新建Web服務擴展"框中輸入擴展名"HTTP Compression",添加"要求的文件"為C:\WINDOWS\system32\inetsrv\gzip.dll,其中Windows系統目錄根據您的安裝可能有所不同,選中"設置擴展狀態為允許";

      image

      3.使用文本編輯器打開C:\Windows\System32\inetsrv\MetaBase.xml(建議先備份),

      找到Location ="/LM/W3SVC/Filters/Compression/gzip用于設置gzip壓縮,

      找到Location ="/LM/W3SVC/Filters/Compression/deflate"用于設置deflate壓縮.

      上面兩個節點緊挨著.并且設置的屬性相同.

      如果需要壓縮動態文件,則將HcDoDynamicCompression設置為"TRUE",并在HcScriptFileExtensions中增加您要壓縮的動態文件后綴名,如aspx;如果需要壓縮靜態文件,則將HcDoStaticCompression和HcDoOnDemandCompression設置為"TRUE",并在HcFileExtensions中增加您需要壓縮的靜態文件后綴名,如xml、css等;HcDynamicCompressionLevel和HcOnDemandCompLevel表示需要的壓縮率,數值在0-10, 默認為0.

      HcDynamicCompressionLevel屬性說明:HcDynamicCompressionLevel Metabase Property

      HcOnDemandCompLevel 屬性說明:HcOnDemandCompLevel Metabase Property

      說明: 這兩個屬性值一般推薦設置為9, 具有最佳性價比.但是在我的window server 2003上, 壓縮率無論如何設置, jQuery和jQuery UI兩個文件(58k/188k)壓縮后的大小一直相同.(20k/45k).

      下面是我的實例:

    <IIsCompressionScheme    Location ="/LM/W3SVC/Filters/Compression/deflate"
           HcCompressionDll="%windir%\system32\inetsrv\gzip.dll"
           HcCreateFlags="0"
           HcDoDynamicCompression="TRUE"
           HcDoOnDemandCompression="TRUE"
           HcDoStaticCompression="true"
           HcDynamicCompressionLevel="9"
           HcFileExtensions="htm
                        html
                        txt
                        js
                        css 
                        swf
                        xml"
           HcOnDemandCompLevel="9"
           HcPriority="1"
           HcScriptFileExtensions="asp 
               aspx
               dll
               exe"
       ></IIsCompressionScheme><IIsCompressionScheme    Location ="/LM/W3SVC/Filters/Compression/gzip"
           HcCompressionDll="%windir%\system32\inetsrv\gzip.dll"
           HcCreateFlags="1"
           HcDoDynamicCompression="TRUE"
           HcDoOnDemandCompression="TRUE"
           HcDoStaticCompression="true"
           HcDynamicCompressionLevel="9"
           HcFileExtensions="htm
                        html
                        txt
                        js
                        css 
                        swf
                        xml"
           HcOnDemandCompLevel="9"
           HcPriority="1"
           HcScriptFileExtensions="asp 
               aspx
               dll
               exe"
       ></IIsCompressionScheme>

      4.編輯完畢后保存MetaBase.xml文件;如果文件無法保存,則可能IIS正在使用該文件。打開"開始"->"管理工具"->"服務",停止"IIS Admin Service"后,即可保存;

      5.最后,重新啟動IIS。可以到HTTP壓縮測試網站驗證結果.以jQuery為例, 核心類庫和UI類庫原始大小分別是57k和188k,壓縮后分別是20k和45k:

      image

      我們通過Http頭中的: Content-Encoding:gzip 屬性判斷返回后的數據已經啟用了gzip壓縮:

      image

      使用YSlow檢測, 當只啟動靜態文件壓縮時, Gzip壓縮評級為B:

      image

      當同時啟動了動態文件壓縮時, Gzip壓縮評級為A:

      image

      六.要點總結

      1. 在修改MetaBase.xml文件時, 要停止"IIS Admin Service"服務. 否則無法保存.

      2.靜態壓縮和動態壓縮率最好設置為9.

      3.上文的步驟2, 即使不添加Web服務擴展效果也是相同的.

      4.壓縮率設置對js文件不起作用, 壓縮后大小總是相同的.

      5.圖片文件即使啟用了gzip壓縮大小也沒有變化.

      七. 總結

      本文總結了如何在IIS中啟用Gzip壓縮. 在半年前的項目中我為網站啟用了Gzip, 今天整理此文主要為了整理自己的知識以便以后忘記時復習. 另外經查看ChinaCache公司提供的CDN也都啟用了Gzip壓縮.

      --cnblogs


    国产亚洲精品美女2020久久| 中文字幕乱码亚洲精品一区| 国色精品va在线观看免费视频| 日韩人妻无码精品一专区| 无码人妻精品一区二区三区9厂 | 91精品国产自产在线老师啪| 久久国产精品61947| 国产精品香港三级国产AV| 国产亚洲精品激情都市| 性欧洲精品videos| 最新精品露脸国产在线| 成人精品视频99在线观看免费| 亚洲人成电影网站国产精品| 国产精品日韩专区| 无码日韩精品一区二区免费| 精品日韩99亚洲的在线发布| 国产精品91在线| 91精品国产亚洲爽啪在线影院| 亚洲国产精品热久久| 久久精品国1国二国三| 国产精品视频一区二区三区无码| 国产成人精品无码一区二区三区| 国产亚洲精品线观看动态图| 久久久久久国产精品无码下载| 国产成人精品视频2021| 任我爽精品视频在线播放| 四虎成人精品在永久在线 | 国产69精品久久久久9999| 日韩精品一区二区三区影院| 精品中文字幕一区在线| 日本精品一区二区久久久| 动漫精品专区一区二区三区不卡 | 国产剧情国产精品一区| 国产亚洲一区二区精品| 国产精品无码久久久久久| 亚洲AV永久无码精品| 色一乱一伦一图一区二区精品| 99热这里只有精品国产动漫| 久久精品国产亚洲一区二区三区| 国产精品尹人在线观看| 久久亚洲国产精品123区|