CDN緩存命中率低會導致源站壓力大,靜態資源訪問效率低。您可以根據導致CDN緩存命中率低的具體原因,選擇對應的優化策略來提高CDN的緩存命中率。
背景信息
CDN通過將靜態資源緩存在CDN節點上實現資源訪問加速。當客戶端訪問某資源時,如果CDN節點上已經緩存了該資源,用戶請求會命中CDN節點上的緩存,直接從緩存中獲取資源返回給用戶,可避免通過較長的鏈路回源,提高資源的響應速度和降低源站的帶寬壓力。如果CDN緩存命中率低,會影響用戶體驗和增加源站的帶寬壓力。
CDN緩存命中率包括字節命中率和請求命中率:
- 字節命中率=CDN緩存命中響應的字節數÷CDN所有請求響應的字節數 說明 字節命中率越低,回源流量越大,源站的流出流量越大,源站的帶寬資源以及其他的負載越大,因此回源流量代表了源站服務器接收到的負載壓力,在業務使用中主要關心字節命中率。
- 請求命中率=CDN緩存命中的請求數÷CDN所有的請求數
查看CDN緩存命中率
查看CDN緩存命中率的方式如下:
- 方法一:通過控制臺查看
- 方法二:調用API查看
- 資源監控功能對應的API
API 描述 DescribeDomainHitRateData 獲取加速域名的字節命中率數據,支持獲取最近90天的數據。 DescribeDomainReqHitRateData 獲取加速域名的請求命中率數據,支持獲取最近90天的數據。 - 實時監控功能對應的API
API 描述 DescribeDomainRealTimeByteHitRateData 獲取加速域名1分鐘粒度的字節命中率數據,支持查詢7天內的數據。 DescribeDomainRealTimeReqHitRateData 獲取加速域名1分鐘粒度的請求命中率數據,支持查詢7天內的數據。
- 資源監控功能對應的API
提高CDN緩存命中率
下表列出了影響CDN緩存命中率的因素和提高CDN緩存命中率的方法。
策略 | 影響因素與應用場景 | 配置方法 |
---|---|---|
業務高峰前預熱熱門資源 | 影響因素:運營大型活動或新版本安裝包發布前,沒有提前將資源預熱到CDN節點,大量資源需要從源站獲取,導致CDN緩存命中率低。 應用場景:
| 預熱資源 |
合理配置緩存過期時間:
| 影響因素:
應用場景:用戶在源站發布了靜態資源,CDN節點沒有將資源緩存下來,或者CDN節點上緩存的資源很快就失效了。 | 配置緩存過期時間 |
去除URL中問號后的參數緩存 | 影響因素:當URL請求中帶有queryString或其他可變參數時,訪問同一個資源的不同URL(URL攜帶的參數不同)會重新回源,導致CDN緩存命中率低。 應用場景:希望通過不同的URL(URL攜帶的參數不同),可以訪問到同一個資源。 | 忽略參數 |
大文件設置分片回源策略 | 影響因素:用戶下載安裝包可能下載一半就停止下載,或者觀看視頻只看了一部分就停止觀看,即用戶只需要訪問資源文件指定范圍內的部分內容,但是CDN節點會向源站請求整個文件,從而使得CDN節點從源站下載的內容大于響應給用戶的內容,導致緩存命中率低。 應用場景:用戶下載應用安裝包或者觀看視頻資源。 | 配置Range回源 |
其他命中率優化策略 | 除了以上幾種常用的命中率優化措施以外,阿里云CDN還有其他的優化措施,這些措施可以根據不同的業務場景來配置,例如:中心302調度、邊緣302調度、合并回源、共享緩存等。 | 由阿里云售后工程師在后臺配置。 |
查看緩存命中狀態日志
在CDN的請求日志中,記錄了所有CDN請求的緩存命中狀態。詳細日志格式,請參見下載日志。
緩存命中狀態字段說明:日志示例:
- HIT:表示命中緩存。
- MISS:表示未命中緩存。
說明 命中狀態僅表示CDN L1節點的命中狀態。例如,CDN L1節點未命中緩存,L2節點命中緩存,日志中仍顯示MISS。
26/Jun/2019:10:38:19 +0800] 192.168.53.146 - 1542 "-" "GET http://example.aliyundoc.com/index.html" 200 191 2830 MISS "Mozilla/5.0 (compatible; AhrefsBot/5.0; +http://example.com/robot/)" "text/html"
您也可以調用DescribeCdnDomainLogs接口,獲取加速域名的日志信息。