打造高性能nginx緩存服務器

 

一、nginx緩存

    Nginx從0.7.48版本開始,支持了類似Squid的緩存功能。這個緩存是把URL及相關組合當作Key,用md5編碼哈希後保存在硬盤上,所以它可以支持任意URL鏈接,同時也支持404/301/302這樣的非200狀態碼。雖然目前官方的Nginx Web緩存服務只能爲指定URL或狀態碼設置過期時間,不支持類似Squid的PURGE指令,手動清除指定緩存頁面,但是,通過一個第三方的Nginx模塊,可以清除指定URL的緩存。 

 

二、如何實現nginx緩存

 

1)實驗圖

 

2)安裝包

nginx-1.5.0.tar.gz

wget http://nginx.org/download/nginx-1.5.0.tar.gz

ngx_cache_purge-2.1.tar.gz

wget http://labs.frickle.com/files/ngx_cache_purge-2.1.tar.gz

 

3)安裝前準備:

在nginx服務器根目錄下創建cache目錄,用於掛在緩存盤或存放緩存數據,名字可以隨便命名,我這裏用的是將4塊磁盤做raid5,掛在到/cache上面。

 

4)安裝:

1 useradd-r www -s /sbin/nologin

2 tar-zvxf ngx_cache_purge-2.1.tar.gz 

3 tar-zvxf nginx-1.5.0.tar.gz

4 cdnginx-1.5.0

5 yum-y install pcre-* openssl-*

6 ./configure \

--prefix=/usr/local/nginx \

--user=www \

--group=www \

--with-http_stub_status_module \

--with-http_ssl_module \

--add-module=/usr/src/ngx_cache_purge-2.1

7 make

8 make install

/usr/local/nginx/sbin/nginx ##start nginx service

 

5)測試nginx:

   firefox http://localhost &

 

看到此測試頁面說明你的nginx安裝成功。

 

 

6) 配置nginx-cache

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

#usernobody;

worker_processes1;

events {

use epoll;

worker_connections 65535;

}

http {

includemime.types;

default_type application/octet-stream; 

sendfile on;

keepalive_timeout 65;

upstream web {

server 192.168.1.201;

server 192.168.1.202;

}

proxy_temp_path/cache/proxy_temp_dir; 

proxy_cache_path /cache/proxy_dir levels=1:2 keys_zone=cache0:200minactive=1d max_size=30g;

server {

listen80;

server_namelocalhost;

location / {

proxy_pass http://web;

proxy_next_upstream http_502 http_504 error timeout invalid_header;

proxy_cache cache0;

proxy_cache_valid 200 304 30m;

proxy_cache_valid any 1m;

proxy_cache_key $host$uri$is_args$args;

proxy_set_header Host$host;

proxy_set_header X-Forwarded-For $remote_addr;

expires 60m;

}

location ~/purge(/.*)

{

allow 127.0.0.1;

allow 192.168.1.0/24;

proxy_cache_purge cache0$host$1$is_args$args;

}

location ~*/.(php|jsp|cgi)?$

{

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $remote_addr;

proxy_pass http://web;

}

error_page500 502 503 504/50x.html;

location = /50x.html{

roothtml;

      }

    }

}

 

7)配置文件關鍵語句解釋

proxy_temp_path/data0/proxy_temp_dir; 

##臨時緩存目錄

proxy_cache_path /data0/proxy_dir levels=1:2 keys_zone=cache0:200minactive=1d max_size=30g;

##定義緩存目錄路徑/data0/proxy_dir

##硬盤緩存中目錄分爲兩級,第一級文件夾名字是1個字母,第二級文件夾名字是兩個字母levels=1:2

##定義緩存區域名字(新建內存緩存區域爲200M)keys_zone=cache0:200m

##緩存內容1天后自動到期清除inactive=1d

##在緩存硬盤上劃分30G空間max_size=30g

##超過2M不緩存max_size=2m

## clean_time指定一分鐘清理一次緩存clean_time=1m

proxy_next_upstream http_502 http_504 errortimeout invalid_header;

##如果後端的服務器返回502、504、執行超時等錯誤,自動將請求轉發到upstream負載均衡池中的另一臺服務器,實現故障轉移。

proxy_cachecache0;

##啓用上述創建的緩存區域cache0

proxy_cache_valid 200 304 30m;

##對返回狀態200 304 緩存30分鐘

proxy_cache_validany 1m;

##對其他狀態碼緩存10分鐘

proxy_cache_key $host$uri$is_args$args;

##以域名、URI、參數組合成Web緩存的Key值,Nginx根據Key值哈希,存儲緩存內容到二級緩存目錄內。指令指定了包含在緩存中的緩存關鍵字。

proxy_set_header Host $host;

##修改客戶GET請求頭中的 HOST字段。在取源的時候保持客戶端的請求字段沒變。

proxy_set_header X-Forwarded-For $remote_addr;

##修改遠端地址,保持在緩存服務器取源的時候,讓源訪問日誌中能記錄到是那個真正遠端客戶地址,否則默認都是認爲是緩存服務器地址,這樣源永遠不知道到底是誰在訪問它。

expires 60m;

##在服務器http響應頭中加入過期時間爲60分鐘,啓用客戶端本地緩存。時間爲60分。

location ~/purge(/.*)

{

allow 127.0.0.1;

allow 192.168.1.0/24;

proxy_cache_purge cache0$host$1$is_args$args;

}

#使用purge工具清除緩存URL

例如需要清除的URL爲:

http://192.168.1.200/test.html

在瀏覽器中訪問

http://192.168.1.200/purge/test.html就可以清除該URL的緩存。

通過訪問控制定義允許那些機器可以使用purge清空URL,不是誰都能隨便清空的。

location ~*/.(php|jsp|cgi)?$

{

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $remote_addr;

proxy_pass http://web;

}

不緩存動態頁面

error_page500 502 503 504/50x.html;

location = /50x.html{

roothtml;

}

錯誤代碼由本機提供頁面

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章