nginx快取使用詳解,nginx快取使用及配置步驟

佚名發表於2022-05-10

  前言

  快取的使用在各種專案中非常普遍,nginx作為一款高效的代理伺服器,也提供了強大的快取機制,試想在一些電商網站中,那些靜態的html,js,css檔案登數量非常龐大的情況下,載入頁面的時候,如果沒有快取的話,頁面將會非常慢,在這種情況下,就可以考慮使用nginx提供的快取功能的配置;

  nginx的web快取

  nginx從0.7.48版提供快取功能。

  nginx是基於proxy store來實現的,其原理是把url及相關組合當做key,在使用md5演算法對key進行雜湊,得到硬碟上對應的雜湊目錄路徑,從而將快取內容儲存在該目錄中。

  它可以支援任意url連線,同時也支援404/301/302這樣的非200狀態碼。nginx即可以支援對指定url或者狀態碼設定過期時間,也可以使用purge命令來手動清除指定url的快取。

  nginx快取設定相關指令

  nginx的web快取服務主要是使用ngx_http_proxy_module模組相關指令集來完成,接下來把常用的指令做一下總結:

proxy_cache_path

  該指定用於設定快取檔案的存放路徑

語法格式

  proxy_cache_path path [levels=number]

  keys_zone=zone_name:zone_size [inactive=time]

  [max_size=size];

  各個引數說明

path

  快取路徑地址

  /usr/local/proxy_cache

levels

  指定該快取空間對應的目錄,最多可以設定3層,每層取值為1|2如 :

  levels=1:2 快取空間有兩層目錄,第一次是1個字母,第二次是2個 字母

  舉例說明:

  zcy[key]透過md5加密以後的值為 : 43c8233266edce38c2c9af0694e2107d

  最終生成的快取目錄含義為:

  levels=1:2 最終的儲存路徑為/usr/local/proxy_cache/d/07;

  levels=2:1:2 最終的儲存路徑為/usr/local/proxy_cache/7d/0/21;

  levels=2:2:2 最終的儲存路徑為??/usr/local/proxy_cache/7d/10/e2

keys_zone

  用來為這個快取區設定名稱和指定大小

  舉例說明:

  keys_zone=zcy:200m 快取區的名稱是zcy,大小為200m,1m 大概能儲存8000個keys

inactive

  指定快取的資料多次時間未被訪問就將被刪除

  舉例說明

  inactive=1d 快取資料在1天內沒有被訪問就會被刪除

max_size

  設定最大快取空間,如果快取空間存滿,預設會覆蓋快取時間最長的資源,如:max_size=20g

  配置例項

proxy_cache_path d:\\dev-tools\\nginx\\nginx-1.16.1\\caches\\proxy_cache keys_zone=zcy:200m levels=1:2:1 inactive=1d max_size=20g;


  下面在本地的nginx目錄下建立一個caches的目錄,將上面的這段配置加到nginx.conf配置檔案中,注意加到http塊中:  實驗演示

  然後重啟nginx服務,可以看到在該目錄下生成了 proxy_cache 目錄,即為快取的目錄

  其他配置引數說明

1、proxy_cache

  該指令用來開啟或關閉代理快取,如果是開啟則自定使用哪個快取區來

  進行快取;

2、proxy_cache_key

  該指令用來設定web快取的key值,nginx會根據key值md5雜湊存快取;

3、proxy_cache_valid

  該指令用來對不同返回狀態碼的url設定不同的快取時間

  例如:

  proxy_cache_valid 200 302 10m;

  proxy_cache_valid 404 1m; 為200和302的響應url設定10分鐘快取,為404的響應url設定1分鐘緩 存;

  proxy_cache_valid any 1m; 對所有響應狀態碼的url都設定1分鐘快取;

4、proxy_cache_min_uses

  該指令用來設定資源被訪問多少次後被快取

5、proxy_cache_methods

  該指令使用者設定快取哪些http方法

  快取配置案例展示

  環境準備

1、tomcat8.0,提前啟動服務;

2、nginx服務,提前啟動;

3、提前準備一個靜態檔案

  可以是html,js或圖片登靜態資源,然後放到tomcat的webapps目錄下的html目錄下

  確保透過tomcat的8080埠可以訪問到該靜態資原始檔

  配置步驟

  開啟nginx的配置檔案,修改nginx.conf,新增如下內容(注意下面的配置放到http模組下);

  我們的需求是:透過訪問 nginx監聽的本地的8081埠,可以直接訪問到tomcat下的這個靜態html檔案,然後測試快取目錄下的檔案是否生成和生效;

proxy_cache_path d:\\dev-tools\\nginx\\nginx-1.16.1\\caches\\proxy_cache keys_zone=zcy:200m levels=1:2:1 inactive=1d max_size=20g;
server {
listen 8081;
server_name localhost ;
location / {
proxy_cache zcy;
proxy_cache_key zcy;
proxy_cache_valid 200 1d;
add_header nginx-cache "$upstream_cache_status"; #瀏覽器可檢視快取的命中狀態
proxy_pass http://localhost:8080/html/hello.html ;
}
}
 

  新增完畢後,使用 : nginx -s reload命令使配置生效,訪問 : localhost:8081,可以看到,直接顯示了該靜態資源

  這時候去本地的快取目錄下,可以看到已經生成了該靜態檔案相關的快取資源;

  如何驗證透過瀏覽器訪問的時候確實是走了快取呢?我們開啟f12透過下面的這個地方就可以看到

  這時候我們去快取目錄下刪掉裡面的檔案後再次測試,看到這個狀態變成了 “miss”

  nginx設定資源不快取

  前面初步完成了nginx作為web快取伺服器的使用的配置說明;

  但是在某些場景下,並不是所有的資料都適合進行快取。比如說對於一些經常發生變化的資料。如果進行快取的話,就很容易出現使用者訪問到的資料不是伺服器真實的資料。所以對於這些資源我們在快取的過程中就需要進行過濾,不進行快取;

  nginx也提供了這塊的功能設定,需要使用到如下兩個指令:

  proxy_no_cache #該指令是用來定義不將資料進行快取的條件

  配置例項:

  proxy_no_cache $cookie_nocache $arg_nocache $arg_comment;

  案例展示

  仍然以上面的案例配置為例,我們在nginx.conf配置中新增如下內容:

  然後重啟nginx,下面做過簡單的測試吧

  刪除本地快取目錄下的檔案後,訪問html資源,這次在訪問的url後面新增上面的配置引數

  可以看到不管訪問多少,都不會對訪問到的靜態資源進行快取,即在請求的url中,拼接上面的3個引數中任意一個即可;

方式2:透過if 條件語句進行設定

  即在location中新增 if 條件表示式,當訪問的url中帶有 .html結尾的字尾時,設定一個mynocache 的變數,並把這個變數設定到proxy_no_cache 中

server {
listen 8081;
server_name localhost ;
location / {
if ($request_uri ~ /.*\.html$){
set $mynocache 1;
}
proxy_cache zcy;
proxy_cache_key zcy;
proxy_cache_valid 200 1d;
proxy_no_cache $cookie_nocache $arg_nocache $arg_comment $mynocache;
add_header nginx-cache "$upstream_cache_status";
proxy_pass http://localhost:8080/html/hello.html ;
}
}


  該指令是用來設定不從快取中獲取資料的條件,即訪問的資源會被快取,但是請求之後的取值不從快取中獲取;  proxy_cache_bypass

配置樣例

  proxy_cache_bypass $cookie_nocache $arg_nocache $arg_comment;

  上述兩個指令都有一個指定的條件,這個條件可以是多個,並且多個條件中至少有一個不為空且不等於"0",則條件滿足成立。上面給的配置例項是從官方網站獲取的,裡面使用到了三個變數,分別是 c o o k i e n o c a c h e 、 cookie_nocache、 cookien​ocache、arg_nocache、$arg_comment

  例項展示

  仍然以上面的配置為例進行說明,當使用proxy_cache_bypass 的時候,需要將proxy_no_cache註釋一下

proxy_cache_path d:\\dev-tools\\nginx\\nginx-1.16.1\\caches\\proxy_cache keys_zone=zcy:200m levels=1:2:1 inactive=1d max_size=20g;
server {
listen 8081;
server_name localhost ;
location / {
#if ($request_uri ~ /.*\.js$){
# set $mynocache 1;
#}
proxy_cache zcy;
proxy_cache_key zcy;
proxy_cache_valid 200 1d;
#proxy_no_cache $cookie_nocache $arg_nocache $arg_comment $mynocache;
proxy_cache_bypass $cookie_nocache $arg_nocache $arg_comment;
add_header nginx-cache "$upstream_cache_status";
proxy_pass http://localhost:8080/html/hello.html ;
}
}
 

  下面來做一個測試吧,首先清理掉快取目錄下的檔案,然後使用後面拼接引數的形式訪問下,結果發現,快取目錄下正常生成了快取檔案,但是此時響應的請求資源並未走快取

  到此這篇關於nginx快取使用詳解的文章就介紹到這了

相關文章