欧美日韩精品在线,国内精品久久久久久久久,一级毛片恃级毛片直播,清纯唯美亚洲综合欧美色

nginx緩存cache的5種方案_負(fù)載集群教程

編輯Tag賺U幣

貌似從來(lái)沒(méi)有寫(xiě)過(guò)nginx的緩存功能,都是只看不分享,這是不好之習(xí)慣啊。

1、傳統(tǒng)緩存之一(404)

這個(gè)辦法是把nginx的404錯(cuò)誤定向到后端,然后用proxy_store把后端返回的頁(yè)面保存。

配置:

location / {
root /home/html/;#主目錄
expires 1d;#網(wǎng)頁(yè)的過(guò)期時(shí)間
error_page 404 =200 /fetch$request_uri;#404定向到/fetch目錄下
}

location /fetch/ {#404定向到這里
internal;#指明這個(gè)目錄不能在外部直接訪問(wèn)到
expires 1d;#網(wǎng)頁(yè)的過(guò)期時(shí)間
alias /home/html/;#虛擬目錄文件系統(tǒng)地址要和locaion /一致,proxy_store會(huì)將文件保存到這目錄下
proxy_pass http://www.sudone.com/;#后端upstream地址,/fetch同時(shí)是一個(gè)代理
proxy_set_header Accept-Encoding '';#讓后端不要返回壓縮(gzip或deflate)的內(nèi)容,保存壓縮后的內(nèi)容會(huì)引發(fā)亂子。
proxy_store on;#指定nginx將代理返回的文件保存
proxy_temp_path /home/tmp;#臨時(shí)目錄,這個(gè)目錄要和/home/html在同一個(gè)硬盤(pán)分區(qū)內(nèi)
}

使用的時(shí)候還有要注意是nginx要有權(quán)限往/home/tmp和/home/html下有寫(xiě)入文件的權(quán)限,在linux下nginx一般會(huì)配置成nobody用戶(hù)運(yùn)行,這樣這兩個(gè)目錄就要chown nobody,設(shè)成nobody用戶(hù)專(zhuān)用,當(dāng)然也可以chmod 777,不過(guò)所有有經(jīng)驗(yàn)的系統(tǒng)管理員都會(huì)建議不要隨便使用777。

2、傳統(tǒng)緩存之二(!-e)

原理和404跳轉(zhuǎn)基本一致,但更簡(jiǎn)潔一些:

location / {
root /home/html/;
proxy_store on;
proxy_set_header Accept-Encoding '';
proxy_temp_path /home/tmp;
if ( !-f $request_filename )
{
        proxy_pass http://www.sudone.com/;
}
}

可以看到這個(gè)配置比404節(jié)約了不少代碼,它是用!-f來(lái)判斷請(qǐng)求的文件在文件系統(tǒng)上存不存在,不存在就proxy_pass到后端,返回同樣是用proxy_store保存。

兩種傳統(tǒng)緩存都有著基本一樣的優(yōu)點(diǎn)和缺點(diǎn):
缺點(diǎn)1:不支持帶參數(shù)的動(dòng)態(tài)鏈接,比如read.php?id=1,因?yàn)閚ginx只保存文件名,所以這個(gè)鏈接只在文件系統(tǒng)下保存為read.php,這樣用戶(hù)訪問(wèn)read.php?id=2時(shí)會(huì)返回不正確的結(jié)果。同時(shí)不支持http://www.sudone.com/這種形式的首頁(yè)和二級(jí)目錄http://www.sudone.com/download/,因?yàn)閚ginx非常老實(shí),會(huì)將這樣的請(qǐng)求照鏈接寫(xiě)入文件系統(tǒng),而這個(gè)鏈接顯然是一個(gè)目錄,所以保存失敗。這些情況都需要寫(xiě)rewrite才能正確保存。
缺點(diǎn)2:nginx內(nèi)部沒(méi)有緩存過(guò)期和清理的任何機(jī)制,這些緩存的文件會(huì)永久性地保存在機(jī)器上,如果要緩存的東西非常多,那就會(huì)撐暴整個(gè)硬盤(pán)空間。為此可以使用一個(gè)shell腳本定期清理,同時(shí)可以撰寫(xiě)php等動(dòng)態(tài)程序來(lái)做實(shí)時(shí)更新。
缺點(diǎn)3:只能緩存200狀態(tài)碼,因此后端返回301/302/404等狀態(tài)碼都不會(huì)緩存,假如恰好有一個(gè)訪問(wèn)量很大的偽靜態(tài)鏈接被刪除,那就會(huì)不停穿透導(dǎo)致后端承載不小壓力。
缺點(diǎn)4:nginx不會(huì)自動(dòng)選擇內(nèi)存或硬盤(pán)作為存儲(chǔ)介質(zhì),一切由配置決定,當(dāng)然在當(dāng)前的操作系統(tǒng)里都會(huì)有操作系統(tǒng)級(jí)的文件緩存機(jī)制,所以存在硬盤(pán)上也不需要過(guò)分擔(dān)心大并發(fā)讀取造成的io性能問(wèn)題。

nginx傳統(tǒng)緩存的缺點(diǎn)也是它和squid等緩存軟件的不同之特色,所以也可看作其優(yōu)點(diǎn)。在生產(chǎn)應(yīng)用中它常常用作和squid的搭檔,squid對(duì)于帶?的鏈接往往無(wú)法阻擋,而nginx能將其訪問(wèn)攔住,例如:http://sudone.com/?和http://sudone.com/在squid上會(huì)被當(dāng)做兩個(gè)鏈接,所以會(huì)造成兩次穿透;而nginx只會(huì)保存一次,無(wú)論鏈接變成http://sudone.com/?1還是http://sudone.com/?123,均不能透過(guò)nginx緩存,從而有效地保護(hù)了后端主機(jī)。

nginx會(huì)非常老實(shí)地將鏈接形式保存到文件系統(tǒng)中,這樣對(duì)于一個(gè)鏈接,可以很方便地查閱它在緩存機(jī)器上的緩存狀態(tài)和內(nèi)容,也可以很方便地和別的文件管理器如rsync等配合使用,它完完全全就是一個(gè)文件系統(tǒng)結(jié)構(gòu)。

這兩種傳統(tǒng)緩存都可以在linux下將文件保存到/dev/shm里,一般我也是這么做的,這樣可以利用系統(tǒng)內(nèi)存來(lái)做緩存,利用內(nèi)存的話(huà),清理過(guò)期內(nèi)容速度就會(huì)快得多。使用/dev/shm/時(shí)除了要把tmp目錄也指向到/dev/shm這個(gè)分區(qū)外,如果有大量小文件和目錄,還要修改一下這個(gè)內(nèi)存分區(qū)的inode數(shù)量和最大容量:

mount -o size=2500M -o nr_inodes=480000 -o noatime,nodiratime -o remount /dev/shm

上面的命令在一臺(tái)有3G內(nèi)存的機(jī)器上使用,因?yàn)?dev/shm默認(rèn)最大內(nèi)存是系統(tǒng)內(nèi)存的一半就是1500M,這條命令將其調(diào)大成2500M,同時(shí)shm系統(tǒng)inode數(shù)量默認(rèn)情況下可能是不夠用的,但有趣的是它可以隨意調(diào)節(jié),這里調(diào)節(jié)為480000保守了點(diǎn),但也基本夠用了。

3、基于memcached的緩存

nginx對(duì)memcached有所支持,但是功能并不是特別之強(qiáng),性能上還是非常之優(yōu)秀。

location /mem/ {
    if ( $uri ~ "^/mem/([0-9A-Za-z_]*)$" )
    {
     set $memcached_key "$1";
     memcached_pass     192.168.1.2:11211;
    }
    expires 70;
}

這個(gè)配置會(huì)將http://sudone.com/mem/abc指明到memcached的abc這個(gè)key去取數(shù)據(jù)。

nginx目前沒(méi)有寫(xiě)入memcached的任何機(jī)制,所以要往memcached里寫(xiě)入數(shù)據(jù)得用后臺(tái)的動(dòng)態(tài)語(yǔ)言完成,可以利用404定向到后端去寫(xiě)入數(shù)據(jù)。

4、基于第三方插件ncache

ncache是新浪兄弟開(kāi)發(fā)的一個(gè)不錯(cuò)的項(xiàng)目,它利用nginx和memcached實(shí)現(xiàn)了一部分類(lèi)似squid緩存的功能,我并沒(méi)有使用這個(gè)插件的經(jīng)驗(yàn),可以參考:

http://code.google.com/p/ncache/

5、nginx新開(kāi)發(fā)的proxy_cache功能

從nginx-0.7.44版開(kāi)始,nginx支持了類(lèi)似squid較為正規(guī)的cache功能,目前還處于開(kāi)發(fā)階段,支持相當(dāng)有限,這個(gè)緩存是把鏈接用md5編碼hash后保存,所以它可以支持任意鏈接,同時(shí)也支持404/301/302這樣的非200狀態(tài)。

配置:

首先配置一個(gè)cache空間:

proxy_cache_path /path/to/cache levels=1:2 keys_zone=NAME:10m inactive=5m max_size=2m clean_time=1m;

注意這個(gè)配置是在server標(biāo)簽外,levels指定該緩存空間有兩層hash目錄,第一層目錄是1個(gè)字母,第二層為2個(gè)字母,保存的文件名就會(huì)類(lèi)似/path/to/cache/c/29/b7f54b2df7773722d382f4809d65029c;keys_zone為這個(gè)空間起個(gè)名字,10m指空間大小為10MB;inactive的5m指緩存默認(rèn)時(shí)長(zhǎng)5分鐘;max_size的2m是指單個(gè)文件超過(guò)2m的就不緩存;clean_time指定一分鐘清理一次緩存。

location / {
    proxy_pass http://www.sudone.com/;

    proxy_cache NAME;#使用NAME這個(gè)keys_zone

    proxy_cache_valid 200 302 1h;#200和302狀態(tài)碼保存1小時(shí)
    proxy_cache_valid 301 1d;#301狀態(tài)碼保存一天
    proxy_cache_valid any 1m;#其它的保存一分鐘
}

ps:支持cache的0.7.44到0.7.51這幾個(gè)版本的穩(wěn)定性均有問(wèn)題,訪問(wèn)有些鏈接會(huì)出現(xiàn)錯(cuò)誤,所以這幾個(gè)版本最好不要在生產(chǎn)環(huán)境中使用。nginx-0.7下目前所知較為穩(wěn)定的版本是0.7.39。穩(wěn)定版0.6.36版也是近期更新,如果在配置里沒(méi)有使用到0.7的一些新標(biāo)簽新功能,也可以使用0.6.36版。

來(lái)源:網(wǎng)絡(luò)搜集//所屬分類(lèi):負(fù)載集群教程/更新時(shí)間:2013-04-14
相關(guān)負(fù)載集群教程