1. 程式人生 > >設定nginx及tomcat啟用GZIP壓縮

設定nginx及tomcat啟用GZIP壓縮

原理簡介

        HTTP 壓縮可以大大提高瀏覽網站的速度,它的原理是,在客戶端請求伺服器對應資源後,從伺服器端將資原始檔壓縮,再輸出到客戶端,由客戶端的瀏覽器負責解壓縮並瀏覽。相對於普通的瀏覽過程HTML ,CSS,Javascript , Text ,它可以節省40%左右的流量。更為重要的是,它可以對動態生成的,包括CGI、PHP , JSP , ASP , Servlet,SHTML等輸出的網頁也能進行壓縮,壓縮效率也很高。 

配置方法

Tomcat5.0以後的版本是支援對輸出內容進行壓縮的,使用的是gzip壓縮格式 。修改%TOMCAT_HOME%/conf/server.xml,修訂節點如下:
  1. <
    Connectorport="80"protocol="HTTP/1.1"
  2.            connectionTimeout="20000"
  3.            redirectPort="8443"executor="tomcatThreadPool"URIEncoding="utf-8"
  4.                        compression="on"
  5.                        compressionMinSize="50"noCompressionUserAgents="gozilla, traviata"
  6.                        compressableMimeType
    ="text/html,text/xml,text/javascript,text/css,text/plain"/>
 
  從上面節點的屬性可以看出,要使用gzip壓縮功能,你需要在Connector節點中加上如下屬性

  • compression="on" 開啟壓縮功能 
  • compressionMinSize="50" 啟用壓縮的輸出內容大小,預設為2KB 
  • noCompressionUserAgents="gozilla, traviata" 對於以下的瀏覽器,不啟用壓縮 
  • compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain
    " 哪些資源型別需要壓縮

測試方法

啟用了TOMCAT這個壓縮功能後,我們如何來測試壓縮是否有效呢?首先Tomcat是根據瀏覽器請求頭中的accept-encoding來判斷瀏覽器是否支援壓縮功能,如果這個值包含有gzip,就表明瀏覽器支援gzip壓縮內容的瀏覽,我們可以用兩種方法來驗證壓縮是否生效。

通過瀏覽器直接請求

       大家直接通過瀏覽器訪問啟用了壓縮配置的伺服器,然後通過抓包工具檢視抓到的資料包,如果內容有很多你看不懂,就說明已經啟用壓縮功能了。

通過程式模擬請求

我們用httpclient寫一個簡單的測試程式,程式碼如下: 
  1. @Test
  2. publicvoid testGzip() {  
  3.         HttpClient httpClient = new HttpClient();  
  4.         GetMethod getMethod = new GetMethod("http://localhost/admin.jsp");  
  5.         try {  
  6.                 getMethod.addRequestHeader("accept-encoding""gzip,deflate");  
  7.                 getMethod.addRequestHeader("user-agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0; Alexa Toolbar; Maxthon 2.0)");  
  8.                 int result = httpClient.executeMethod(getMethod);  
  9.                 if (result == 200) {  
  10.                         System.out.println(getMethod.getResponseContentLength());  
  11.                         String html = getMethod.getResponseBodyAsString();  
  12.                         System.out.println(html);  
  13.                         System.out.println(html.getBytes().length);  
  14.                 }  
  15.         } catch (HttpException e) {  
  16.                 e.printStackTrace();  
  17.         } catch (IOException e) {  
  18.                 e.printStackTrace();  
  19.         } finally {  
  20.                 getMethod.releaseConnection();  
  21.         }  
  22. }  

  執行這個junit程式,看看它所輸出的是什麼內容,如果輸出的是一些亂碼,並且列印內容的長度遠小於實際的長度,就說明我們的配置生效了,通過一些其它驗證工具,會發現網站瀏覽速度會明顯提升。備註:如果發現內容沒有被壓縮,可以考慮調整compressionMinSize大小,如果請求資源小於這個數值,則不會啟用壓縮。

剛剛給部落格加了一個500px相簿外掛,lightbox引入了很多js檔案和css檔案,頁面一下子看起來非常臃腫,所以還是把Gzip打開了。

環境:Debian 6

1、Vim開啟Nginx配置檔案

vim /usr/local/nginx/conf/nginx.conf

2、找到如下一段,進行修改

gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
#gzip_http_version 1.0;
gzip_comp_level 2;
gzip_types text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
gzip_vary off;
gzip_disable "MSIE [1-6]\.";

3、解釋一下

第1行:開啟Gzip

第2行:不壓縮臨界值,大於1K的才壓縮,一般不用改

第3行:buffer,就是,嗯,算了不解釋了,不用改

第4行:用了反向代理的話,末端通訊是HTTP/1.0,有需求的應該也不用看我這科普文了;有這句的話註釋了就行了,預設是HTTP/1.1

第5行:壓縮級別,1-10,數字越大壓縮的越好,時間也越長,看心情隨便改吧

第6行:進行壓縮的檔案型別,缺啥補啥就行了,JavaScript有兩種寫法,最好都寫上吧,總有人抱怨js檔案沒有壓縮,其實多寫一種格式就行了

第7行:跟Squid等快取服務有關,on的話會在Header裡增加"Vary: Accept-Encoding",我不需要這玩意,自己對照情況看著辦吧

第8行:IE6對Gzip不怎麼友好,不給它Gzip了

4、:wq儲存退出,重新載入Nginx

/usr/local/nginx/sbin/nginx -s reload

5、用curl測試Gzip是否成功開啟

curl -I -H "Accept-Encoding: gzip, deflate" "//www.slyar.com/blog/"

HTTP/1.1 200 OK
Server: nginx/1.0.15
Date: Sun, 26 Aug 2012 18:13:09 GMT
Content-Type: text/html; charset=UTF-8
Connection: keep-alive
X-Powered-By: PHP/5.2.17p1
X-Pingback: //www.slyar.com/blog/xmlrpc.php
Content-Encoding: gzip

頁面成功壓縮

curl -I -H "Accept-Encoding: gzip, deflate" "//www.slyar.com/blog/wp-content/plugins/photonic/include/css/photonic.css"

HTTP/1.1 200 OK
Server: nginx/1.0.15
Date: Sun, 26 Aug 2012 18:21:25 GMT
Content-Type: text/css
Last-Modified: Sun, 26 Aug 2012 15:17:07 GMT
Connection: keep-alive
Expires: Mon, 27 Aug 2012 06:21:25 GMT
Cache-Control: max-age=43200
Content-Encoding: gzip

css檔案成功壓縮

curl -I -H "Accept-Encoding: gzip, deflate" "//www.slyar.com/blog/wp-includes/js/jquery/jquery.js"

HTTP/1.1 200 OK
Server: nginx/1.0.15
Date: Sun, 26 Aug 2012 18:21:38 GMT
Content-Type: application/x-javascript
Last-Modified: Thu, 12 Jul 2012 17:42:45 GMT
Connection: keep-alive
Expires: Mon, 27 Aug 2012 06:21:38 GMT
Cache-Control: max-age=43200
Content-Encoding: gzip

js檔案成功壓縮

curl -I -H "Accept-Encoding: gzip, deflate" "//www.slyar.com/blog/wp-content/uploads/2012/08/2012-08-23_203542.png"

HTTP/1.1 200 OK
Server: nginx/1.0.15
Date: Sun, 26 Aug 2012 18:22:45 GMT
Content-Type: image/png
Last-Modified: Thu, 23 Aug 2012 13:50:53 GMT
Connection: keep-alive
Expires: Tue, 25 Sep 2012 18:22:45 GMT
Cache-Control: max-age=2592000
Content-Encoding: gzip

圖片成功壓縮

curl -I -H "Accept-Encoding: gzip, deflate" "//www.slyar.com/blog/wp-content/plugins/wp-multicollinks/wp-multicollinks.css"

HTTP/1.1 200 OK
Server: nginx/1.0.15
Date: Sun, 26 Aug 2012 18:23:27 GMT
Content-Type: text/css
Content-Length: 180
Last-Modified: Sat, 02 May 2009 08:46:15 GMT
Connection: keep-alive
Expires: Mon, 27 Aug 2012 06:23:27 GMT
Cache-Control: max-age=43200
Accept-Ranges: bytes