1. Nginx的簡介
相關(guān)內(nèi)容凯肋,可以查看 【Nginx 負載均衡】方面,這是我之前的一篇文章,這里就懶得再說明一次了颂碧。
2. Nginx緩存簡介
nginx的http_proxy模塊始锚,可以實現(xiàn)類似于Squid的緩存功能。
Nginx對客戶已經(jīng)訪問過的內(nèi)容在Nginx服務(wù)器本地建立副本撒遣,這樣在一段時間內(nèi)再次訪問該數(shù)據(jù)邮偎,就不需要通過N ginx服務(wù)器再次向后端服務(wù)器發(fā)出請求,所以能夠減少Nginx服務(wù)器與后端服務(wù)器之間的網(wǎng)絡(luò)流量义黎,減輕網(wǎng)絡(luò)擁塞禾进,同時還能減小數(shù)據(jù)傳輸延遲,提高用戶訪問速度廉涕。
同時泻云,當后端服務(wù)器宕機時艇拍,Nginx服務(wù)器上的副本資源還能夠回應(yīng)相關(guān)的用戶請求,這樣能夠提高后端服務(wù)器的魯棒性(健壯性)。
2.1對于緩存宠纯,我們大概會有下面的幾個疑問:
- 緩存文件放在哪兒卸夕?
- 如何指定那些請求被緩存?
- 緩存的有效期是多久婆瓜?
- 對于某些請求快集,是否可以不走緩存?
解決以上問題廉白,nginx的緩存也就基本配置完成了碍讨。
3. Nginx緩存
3.1 緩存文件放在哪?
- proxy_cache_path:Nginx使用該參數(shù)指定緩存位置蒙秒。
- proxy_cache:該參數(shù)為之前指定的緩存名稱勃黍。
- proxy_cache_path:有兩個必填參數(shù),
- 第一個參數(shù)為緩存目錄晕讲。
- 第二個參數(shù)keys_zone指定緩存名稱和占用內(nèi)存空間的大小覆获。
- 示例:
user www-data;
worker_processes auto; #表示服務(wù)器有幾個內(nèi)核就起幾個work
pid /run/nginx.pid; #進程編號
http {
proxy_cache_path /data/nginx/cache keys_zone=one:10m max_size=10g;
upstream test.lazyfennec.cn {
server 127.0.0.1:8881; # 第一臺服務(wù)器
server 127.0.0.1:8882; # 第二臺服務(wù)器
server 127.0.0.1:8883; # 第三臺服務(wù)器
}
server {
listen 80; # 監(jiān)聽80端口
proxy_cache one; # 指定緩存配置
server_name test.lazyfennec.cn; # 自己的域名或者IP
location / {
proxy_pass http://test.lazyfennec.cn;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
}
注: 示例中的10m是對內(nèi)存中緩存內(nèi)容元數(shù)據(jù)信息大小的限制,如果想限制緩存總量大小瓢省,需要用max_size參數(shù)弄息。
3.2 如何指定哪些請求被緩存?
Nginx 默認會緩存所有g(shù)et 和 head方法的請求結(jié)果勤婚,緩存的key默認使用請求字符串摹量。
自定義key
例如 proxy_cache_key
"$host$request_uri$cookie_user";指定請求至少被發(fā)送了多少次以上時才緩存,可以防止低頻請求被緩存馒胆。
例如 proxy_cache_min_uses 5;指定哪些方法的請求被緩存
例如 proxy_cache_methods GET HEAD POST;
- 示例:
user www-data;
worker_processes auto; #表示服務(wù)器有幾個內(nèi)核就起幾個work
pid /run/nginx.pid; #進程編號
http {
proxy_cache_path /data/nginx/cache keys_zone=one:10m;
upstream test.lazyfennec.cn {
server 127.0.0.1:8881; # 第一臺服務(wù)器
server 127.0.0.1:8882; # 第二臺服務(wù)器
server 127.0.0.1:8883; # 第三臺服務(wù)器
}
server {
listen 80; # 監(jiān)聽80端口
proxy_cache one; # 指定緩存配置
server_name test.lazyfennec.cn; # 自己的域名或者IP
location / {
proxy_pass http://test.lazyfennec.cn;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_cache_key $host$request_uri$cookie_user; # 指定緩存key
}
}
}
3.3 緩存有效期
默認情況下缨称,緩存內(nèi)容是長期存留的,除非緩存的總量超出限制祝迂∧谰。可以指定緩存有效時間,例如:
響應(yīng)狀態(tài)碼為 200 302 時型雳, 10分鐘有效
proxy_cache_valid 200 302 10m;
對應(yīng)任何狀態(tài)碼当凡,5分鐘有效
proxy_cache_valid any 5m;
示例:
user www-data;
worker_processes auto; #表示服務(wù)器有幾個內(nèi)核就起幾個work
pid /run/nginx.pid; #進程編號
http {
proxy_cache_path /data/nginx/cache keys_zone=one:10m;
upstream test.lazyfennec.cn {
server 127.0.0.1:8881; # 第一臺服務(wù)器
server 127.0.0.1:8882; # 第二臺服務(wù)器
server 127.0.0.1:8883; # 第三臺服務(wù)器
}
server {
listen 80; # 監(jiān)聽80端口
proxy_cache one; # 指定緩存配置
server_name test.lazyfennec.cn; # 自己的域名或者IP
location / {
proxy_pass http://test.lazyfennec.cn;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_cache_valid 200 302 10m;
}
}
}
3.4 對于某些請求,是否可以不走緩存纠俭?
proxy_cache_bypass:該指令響應(yīng)來自原始服務(wù)器而不是緩存沿量。
例如proxy_cache_bypass $cookie_nocache $arg_nocache$arg_comment;
如果任何一個參數(shù)值不為空,或者不等于0,nginx就不會查找緩存冤荆,直接進行代理轉(zhuǎn)發(fā)朴则。
- 示例
user www-data;
worker_processes auto; #表示服務(wù)器有幾個內(nèi)核就起幾個work
pid /run/nginx.pid; #進程編號
http {
proxy_cache_path /data/nginx/cache keys_zone=one:10m;
upstream test.lazyfennec.cn {
server 127.0.0.1:8881; # 第一臺服務(wù)器
server 127.0.0.1:8882; # 第二臺服務(wù)器
server 127.0.0.1:8883; # 第三臺服務(wù)器
}
server {
listen 80; # 監(jiān)聽80端口
proxy_cache one; # 指定緩存配置
server_name test.lazyfennec.cn; # 自己的域名或者IP
location / {
proxy_pass http://test.lazyfennec.cn;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_cache_bypass $cookie_nocache $arg_nocache$arg_comment; # 任意參數(shù)不為空則不走緩存
}
}
}
網(wǎng)頁的緩存是由HTTP消息頭中的“Cache-control”來控制的,常見的取值有private匙赞、no-cache佛掖、max-age妖碉、must-revalidate等,默認為private芥被。其作用根據(jù)不同的重新瀏覽方式分為以下幾種情況欧宜。
上圖描述的內(nèi)容,一個示例如下:
basic.conf
其實這里是描述真實服務(wù)器的內(nèi)容(使用代理服務(wù)器轉(zhuǎn)發(fā)到這個端口即可)
conf
user www-data;
worker_processes auto; #表示服務(wù)器有幾個內(nèi)核就起幾個work
pid /run/nginx.pid; #進程編號
events {
use epoll;
worker_connections 65535;
}
http {
proxy_cache_path /data/workspace/cache keys_zone=one:10m max_size=10g inactive=60m;
proxy_cache_key "$scheme$request_method$request_uri";
upstream origin.lazyfennec.cn {
server 127.0.0.1:9000;
}
server {
listen 80; # 監(jiān)聽80端口
proxy_cache one; # 指定緩存配置
server_name test.lazyfennec.cn; # 自己的域名或者IP
location / {
add_header X-proxy-Cache $upsteam_cache_status;
include proxy_params;
proxy_pass http://origin.lazyfennec.cn;
}
}
server {
listen 9000;
root /data/workspace/nodejs/;
index index.html index.htm;
charset utf-8;
include h5dp/basic.conf; # 引入外部的配置文件拴魄,即上邊的圖basic.conf
location / {
try_files $uri $uri/ = 404;
}
}
}
如果覺得有收獲就點個贊吧冗茸,更多知識,請點擊關(guān)注查看我的主頁信息哦~