- 存放靜態(tài)資源文件到服務(wù)器 但這種形式在性能上也有缺陷:
- 受地理環(huán)境影響,離服務(wù)器越遠(yuǎn)資源加載越慢
- 頻繁請(qǐng)求資源對(duì)服務(wù)器壓力較大
- 存放靜態(tài)資源文件到CDN為了進(jìn)一步提升性能,可以把動(dòng)態(tài)網(wǎng)頁(yè)(index.html)和靜態(tài)資源(js、css、image...)分開(kāi)部署。靜態(tài)資源被放置于CDN上. 但是CDN也有緩存策略:新的靜態(tài)資源發(fā)布后,需要一定的時(shí)間去覆蓋各個(gè)邊緣站點(diǎn)的舊資源。若某客戶端獲得了新的動(dòng)態(tài)網(wǎng)頁(yè),但是附近的 CDN節(jié)點(diǎn)尚未更新最近發(fā)布的靜態(tài)資源,客戶端即便放棄本地緩存,它加載的依舊是位于CDN上的“臟數(shù)據(jù)”。怎么辦呢?干脆把文件名也給改了——讓摘要信息成為文件名的一部分!
具體實(shí)現(xiàn)可以仰仗webpack,將output.filename設(shè)為[name].[contenthash].js,輸出文件和 html 模版都會(huì)幫你更改好. 用摘要信息重命名后的資源文件,與舊資源就不同名了,不再需要以覆蓋舊文件的形式主動(dòng)更新各個(gè)地區(qū)的邊緣站點(diǎn)。
新版本發(fā)布后,瀏覽器首次請(qǐng)求資源,若CDN不存在該資源,便會(huì)向就近的邊緣站點(diǎn)加載該文件,同時(shí)更新 CDN 緩存;這就徹底避免了CDN臟數(shù)據(jù)的問(wèn)題.