日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

如何在nginx中缓存静态文件

發(fā)布時間:2025/6/15 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何在nginx中缓存静态文件 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

這篇教程說明你應該怎樣配置 nginx、設置 HTTP 頭部過期時間,用 Cache-Control 中的 max-age 標記為靜態(tài)文件(比如圖片、 CSS 和 Javascript 文件)設置一個時間,這樣用戶的瀏覽器就會緩存這些文件。這樣能節(jié)省帶寬,并且在訪問你的網站時會顯得更快些(如果用戶第二次訪問你的網站,將會使用瀏覽器緩存中的靜態(tài)文件)。

1、準備事項

我想你需要一個正常工作的 nginx 軟件,就像這篇教程里展示的:在 Ubuntu 16.04 LTS 上安裝 Nginx,PHP 7 和 MySQL 5.7 (LEMP)。

2 配置 nginx

可以參考 expires 指令手冊來設置 HTTP 頭部過期時間,這個標記可以放在 http {}、server {}、location {} 等語句塊或者 location {} 語句塊中的條件語句中。一般會在 location 語句塊中用 expires 指令控制你的靜態(tài)文件,就像下面一樣:

  • location?~*??\.(jpg|jpeg|png|gif|ico|css|js)$?{?
  • ???expires?365d;?
  • }?
  • 在上面的例子中,所有后綴名是 .jpg、 .jpeg、 .png、 .gif、 .ico、 .css 和 .js 的文件會在瀏覽器訪問該文件之后的 365 天后過期。因此你要確保 location {} 語句塊僅僅包含能被瀏覽器緩存的靜態(tài)文件。

    然后重啟 nginx 進程:

  • /etc/init.d/nginx?reload?
  • 你可以在 expires 指令中使用以下的時間設置:

    • off 讓 Expires 和 Cache-Control 頭部不能被更改。
    • epoch 將 Expires 頭部設置成 1970 年 1 月 1 日 00:00:01。
    • max 設置 Expires 頭部為 2037 年 12 月 31 日 23:59:59,設置 Cache-Control 的最大存活時間為 10 年
    • 沒有 @ 前綴的時間意味著這是一個與瀏覽器訪問時間有關的過期時間。可以指定一個負值的時間,就會把 Cache-Control 頭部設置成 no-cache。例如:expires 10d 或者 expires 14w3d。
    • 有 @ 前綴的時間指定在一天中的某個時間過期,格式是 Hh 或者 Hh:Mm,H 的范圍是 0 到 24,M 的范圍是 0 到 59,例如:expires @15:34。

    你可以用以下的時間單位:

    • ms: 毫秒
    • s: 秒
    • m: 分鐘
    • h: 小時
    • d: 天
    • w: 星期
    • M: 月 (30 天)
    • y: 年 (365 天)

    例如:1h30m 表示一小時三十分鐘,1y6M 表示一年六個月。

    注意,要是你用一個在將來很久才會過期的頭部,當組件修改時你就要改變組件的文件名。因此給文件指定版本是一個不錯的方法。例如,如果你有個 javascript.js 文件 并且你要修改它,你可以在修改的文件名字后面添加一個版本號。這樣瀏覽器就要下載這個文件,如果你沒有更改文件名,瀏覽器將從緩存里面加載(舊的)文件。

    除了把基于瀏覽器訪問時間設置 Expires 頭部(比如 expires 10d)之外,也可以通過在時間前面的 modified 關鍵字,將 Expires 頭部的基準設為文件修改的時間(請注意這僅僅對存儲在硬盤的實際文件有效)。

  • expires?modified?10d;?
  • 3 測試

    要測試你的配置是否有效,可以用火狐瀏覽器的開發(fā)者工具中的網絡分析功能,然后用火狐訪問一個靜態(tài)文件(比如一張圖片)。在輸出的頭部信息里,應該能看到 Expires 頭部和有 max-age 標記的 Cache-Control 頭部(max-age 標記包含了一個以秒為單位的值,比如 31536000 就是指今后的一年)

    4 鏈接

    nginx 的 Http 頭部模塊(HttpHeadersModule): http://wiki.nginx.org/HttpHeadersModule


    作者:Falko Timme

    來源:51CTO

    《新程序員》:云原生和全面數(shù)字化實踐50位技術專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

    總結

    以上是生活随笔為你收集整理的如何在nginx中缓存静态文件的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。