WEB緩存系統之varnish緩存項修剪

来源:https://www.cnblogs.com/qiuhom-1874/archive/2020/04/09/12666406.html
-Advertisement-
Play Games

對於varninsh來講,緩存項修剪也叫緩存項刪除;我們在varnish伺服器上可以通過vcl語言來編寫緩存策略,對於某些緩存該如何緩存,緩存多久等等;假如我們在定義好緩存策略後,在定義緩存過期時間內,後端伺服器內容發生了變化,或者後端伺服器發生了內容更新,我們如果不把varnish上的緩存修剪掉... ...


  前文我們聊了下varnish的狀態引擎和不同類型的變數對應該使用在那個狀態引擎中,以及每個狀態引擎的對應處理事務;回顧請參考https://www.cnblogs.com/qiuhom-1874/p/12643549.html;今天我們來聊一聊varnish的緩存項修剪;

  什麼是緩存項修剪?所謂修剪我個人的理解是把多餘的部分或者不需要的部分刪除掉;對於varninsh來講,緩存項修剪也叫緩存項刪除;我們在varnish伺服器上可以通過vcl語言來編寫緩存策略,對於某些緩存該如何緩存,緩存多久等等;假如我們在定義好緩存策略後,在定義緩存過期時間內,後端伺服器內容發生了變化,或者後端伺服器發生了內容更新,我們如果不把varnish上的緩存修剪掉,對於用戶來講,用戶的訪問就不是最新的數據;為瞭解決這樣的問題,我們需要人工手動的去修剪緩存項;而修剪緩存項一般都是針對某一類資源或特定資源來做修剪(通過用戶指定或正在匹配),一般不會也不應該是全部;在varnish中,修剪緩存的方式有兩種,一種是vcl_purge狀態引擎修剪(通過判斷用戶的某些請求首部特征,來對用戶指定的資源進行修剪),一種是內部函數ban()來修剪緩存(通常在命令行執行ban命令修剪緩存);

  首先我們來看看varnish的預設配置中如何定義vcl_purge這個狀態引擎的;

[root@test_node1-centos7 ~]# varnishadm -S /etc/varnish/secret -T 127.0.0.1:6082 "vcl.show -v boot"|grep -A3 purge
sub vcl_purge {
    return (synth(200, "Purged"));
}

[root@test_node1-centos7 ~]# 

  提示:從上面預設配置中可以看到對於vcl_purge的配置很簡單;以上配置表示如果上一個狀態引擎把報文送給purge這個狀態引擎後,purge狀態引擎的操作就是把對應報文送給synth(),併合成一個200的響應碼,消息狀態是purged的合成頁面響應給客戶端;以上就是告訴客戶端緩存項修剪成功;

  瞭解了purge的處理機制後,我們在來看看緩存項的修剪應該在那個狀態引擎中定義;通常在接收到用戶請求後,就需要修剪緩存;這樣用戶才可以拿到最新頁面;所以我們在定義緩存的修剪操作應該在vcl_recv中定義;比如判斷用戶的請求方法,如果用戶請求的方法是我們自定義的請求方法,我們就把這類請求直接交給purge處理;

   提示:紅框中的內容就是來判斷用戶的請求方法,如果請求方法是“PURGE” 那麼就把對應的請求交給purge去處理;

  測試:用curl命令指定特定的請求方法去訪問varnish對外提供的頁面;通過判斷響應報文中,之前我們定義的X-Cache首部的值來判斷是否命中緩存;如果我們使用了purge方法後,第二次正常方式訪問應該是miss的,第三次訪問時hit就表示修剪緩存項成功;

[root@test_node1-centos7 ~]# varnishadm -S /etc/varnish/secret -T 127.0.0.1:6082
200        
-----------------------------
Varnish Cache CLI 1.0
-----------------------------
Linux,3.10.0-693.el7.x86_64,x86_64,-sfile,-smalloc,-hcritbit
varnish-4.0.5 revision 07eff4c29

Type 'help' for command list.
Type 'quit' to close CLI session.


varnish> vcl.load test default.vcl
200        
VCL compiled.

varnish> vcl.use test
200        
VCL 'test' now active

varnish> quit
500        
Closing CLI connection
[root@test_node1-centos7 ~]# curl  -I http://192.168.0.99:8000
HTTP/1.1 200 OK
Date: Thu, 09 Apr 2020 04:57:49 GMT
Server: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips
Strict-Transport-Security: max-age=31536000
Last-Modified: Tue, 31 Mar 2020 14:56:54 GMT
ETag: "2f-5a227c743121d"
Content-Length: 47
Content-Type: text/html; charset=UTF-8
X-Varnish: 65541
Age: 0
Via: 1.1 varnish-v4
X-Cache: miss via 192.168.0.99
Connection: keep-alive

[root@test_node1-centos7 ~]# curl  -I http://192.168.0.99:8000
HTTP/1.1 200 OK
Date: Thu, 09 Apr 2020 04:57:49 GMT
Server: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips
Strict-Transport-Security: max-age=31536000
Last-Modified: Tue, 31 Mar 2020 14:56:54 GMT
ETag: "2f-5a227c743121d"
Content-Length: 47
Content-Type: text/html; charset=UTF-8
X-Varnish: 32772 65542
Age: 3
Via: 1.1 varnish-v4
X-Cache: hit via 192.168.0.99
Connection: keep-alive

[root@test_node1-centos7 ~]# curl -X "PURGE" http://192.168.0.99:8000
<!DOCTYPE html>
<html>
  <head>
    <title>200 Purged</title>
  </head>
  <body>
    <h1>Error 200 Purged</h1>
    <p>Purged</p>
    <h3>Guru Meditation:</h3>
    <p>XID: 65544</p>
    <hr>
    <p>Varnish cache server</p>
  </body>
</html>
[root@test_node1-centos7 ~]# curl  -I http://192.168.0.99:8000       
HTTP/1.1 200 OK
Date: Thu, 09 Apr 2020 04:58:11 GMT
Server: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips
Strict-Transport-Security: max-age=31536000
Last-Modified: Tue, 31 Mar 2020 14:56:54 GMT
ETag: "2f-5a227c743121d"
Content-Length: 47
Content-Type: text/html; charset=UTF-8
X-Varnish: 32774
Age: 0
Via: 1.1 varnish-v4
X-Cache: miss via 192.168.0.99
Connection: keep-alive

[root@test_node1-centos7 ~]# curl  -I http://192.168.0.99:8000
HTTP/1.1 200 OK
Date: Thu, 09 Apr 2020 04:58:11 GMT
Server: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips
Strict-Transport-Security: max-age=31536000
Last-Modified: Tue, 31 Mar 2020 14:56:54 GMT
ETag: "2f-5a227c743121d"
Content-Length: 47
Content-Type: text/html; charset=UTF-8
X-Varnish: 32777 32775
Age: 3
Via: 1.1 varnish-v4
X-Cache: hit via 192.168.0.99
Connection: keep-alive

[root@test_node1-centos7 ~]#

  提示:我們用purge方法去請求對應資源後,再用正常的get方法去獲取資源,對應響應報文首部X-Cache的值就變成miss的,說明沒用從緩存中命中;再次訪問X-Cache的值變成hit,說明從緩存中命中,這是因為第一次緩存修剪後,第二次訪問就把該資源緩存到varnish上,再次訪問varnish就直接從緩存中給我們響應;

  其實通過請求方法來判緩存項是否該修剪,其實很危險的;就以上面的配置,任何人都可以通過purge方法去修剪緩存,這很顯然是不能也不應該的;所以我們還需要限定那些用戶可以執行purge方法去修剪緩存;在varnish中添加訪問控製法則需要用acl關鍵指定,然後起一名稱,把對應的ip地址或網段地址寫進去;如下

   提示:以上就表示定義了一個訪問控製法則,其名稱叫做allow_purge_method_clients;其中這裡面寫ip地址需要用雙引號引起來,並用分號結束;對於網段地址掩碼位數需要寫在雙引號外;

  定義好訪問控制規則後,我們在原有的判斷用戶請求方法中加入限定IP地址的操作;

   提示:以上紅框中的內容表示如果用戶請求的方法是PURGE,IP地址不匹配我們指定的ip地址法則,那麼就返回合成403響應碼給客戶;如果匹配就執行purge操作;

  測試:用192.168.0.99這台主機用"PURGE"方法請求修剪和用192.168.0.22這台主機用"PURGE"方法修剪緩存,如果我們定義的緩存策略正確的話,第一臺主機應該是可以修剪緩存的,第二台主機會提示不運行修剪緩存,響應403;

   提示:從上面的示例可以看到通過不同ip的主機對varnish發起“PURGE”方法修剪緩存,在自定義訪問控製法則中存在的IP就可以通過“PURGE”方法來修剪緩存,相反不再acl控制發展中的IP地址主機,就不被允許修剪緩存;

   以上是通過編寫vcl來判斷用戶的請求方法實現緩存修剪,除此之外varnish還支持內建命令ban來修剪緩存;接下來我們來看看用內建命名ban怎麼修剪緩存;

  首先我們可以來查看下ban命令的用法;

   提示:以上就是ban命令的用法,其中field表示用戶請求的某些首部,比如req.http.host、req.url等;operaror表示操作符 ,arg表示參數;

  示例:修剪用戶請求資源是index.html內容

   提示:以上紅框中的內容就相當於判斷用戶請求的url,如果匹配/index.html,就return(synth(200));意思就是說對用戶請求的/index.html的緩存項進行修剪(刪除);所以用戶再次訪問該URL就不會從緩存響應;

  測試:

  提示:把/index.html的緩存項修剪以後,用戶再次訪問到/index.html資源時,從響應首部就可以知道它沒有被緩存命中;說明緩存項修剪時成功的;

  當然在命令行中可以直接使用ban命令修剪緩存,在配置文件中,我們也可以來使用ban函數來對緩存項進行修剪;如下

   提示:以上紅框中的內容表示用戶的請求方法是BAN  就執行ban("req.http.host == " + req.http.host + "&& req.url ==" + req.url),然後通過synth()合成一響應碼為200的頁面響應給用戶;這裡的ban函數參數部分就是一字元串合成;如果用戶請求的host是192.168.0.99 ,url是/index.html;那麼ban函數參數部分就是req.http.host == 192.168.0.99:8000 && req.url == /index.html ,就相當在命令行執行ban req.http.host == 192.168.0.99:8000 && req.url == /index.html ;這裡特別提示“&&”和 “==”號兩邊必須要有空格,否則會把&&識別成req.http.host的值的一部分;

  測試

   提示:我們在配置文件利用判斷用戶請求的方法來修剪緩存項,這種方式同PURGE的方式類似,都需要用acl去控制可以執行修剪操作的客戶端;通常情況下我們如果是臨時修剪緩存項,用ban命令在命令行修剪,很少寫在配置文件中,通過特定的請求方法去修剪特定的資源緩存;而PURGE和ban相反,PURGE常用於在配置文件中用特定的請求方法修剪指定的url資源緩存項;


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 需求很簡單,就是文本框想要個placeholder的效果,中文的時候顯示“姓名”,英文的時候顯示“Name”,於是有了以下代碼: 然後,動態切換成英文資源的時候,發現他還是中文的,暈。後來改成以下代碼就OK了,不知和解? ...
  • public static int AddBook(BookInfo bookInfo) { using (BookDBContext dbContext = new BookDBContext()) { dbContext.BookInfo.Add(bookInfo); return (dbCon ...
  • /// <summary> /// 修改 /// </summary> /// <param name="bookInfo"></param> /// <returns></returns> public static bool Update(BookInfo bookInfo) { using ( ...
  • 必應每天都會更換背景圖片,都非常漂亮,有的時候還十分驚艷,同時還會根據每個地區的特色不同應用不同的圖片。 下麵用c 抓取必應每天的背景圖片,並實現桌面壁紙的每天自動切換 實現思路 1.通過獲取“必應”網頁背景圖片URL 2.下載圖片到本地 3.設置這個圖片為壁紙 4.每日自動切換壁紙 1.創建項目文 ...
  • 1. 升級到Core的好處 去年中我曾考慮將我的控制項庫項目 "Kino.Toolkit.Wpf" 升級到.NET Core,不過很快放棄了,因為當時.NET Core是預覽版,編譯WPF還需要使用最新的Visual Studio 2019,這樣作為一個教學項目不夠友好。到了今天.NET Core 3 ...
  • 在.net環境下,基於Asp.Net Core,利用ZXing來生成二維碼的一般操作。 ...
  • Keil IDE 工具學習 前言 學習過近4年的STM32,通過正點原子的視頻還有資料入門的,裡面的資料很齊全。可是我很少去看除了視頻,原理圖,中文手冊之外的資料。但是最近翻看了一下那些資料發現了許多的寶藏,比如,CM3權威指南,Ucos-ii的講解,個人對基礎比較喜歡,所以沒有去看關於界面EmWi ...
  • Debian 10.3 下載地址: "http://mirrors.163.com/debian cd/10.3.0 live/amd64/iso hybrid/debian live 10.3.0 amd64 standard.iso" 備份 更換 輸入以下內容: 註意許可權問題,否則可能編輯不了此 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...