如何在nginx中配置緩存靜態(tài)文件
這篇教程說明你應(yīng)該怎樣配置 nginx、設(shè)置 HTTP 頭部過期時間,用 Cache-Control 中的 max-age 標記為靜態(tài)文件(比如圖片、 CSS 和 Javascript 文件)設(shè)置一個時間,這樣用戶的瀏覽器就會緩存這些文件。這樣能節(jié)省帶寬,并且在訪問你的網(wǎng)站時會顯得更快些(如果用戶第二次訪問你的網(wǎng)站,將會使用瀏覽器緩存中的靜態(tài)文件)。
1、準備事項
我想你需要一個正常工作的 nginx 軟件,就像這篇教程里展示的:在Ubuntu 16.04 LTS 上安裝 Nginx,PHP 7 和 MySQL 5.7 (LEMP) 。
2 配置 nginx
可以參考 expires 指令手冊來設(shè)置 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
指令中使用以下的時間設(shè)置:
off
讓Expires
和Cache-Control
頭部不能被更改。epoch
將Expires
頭部設(shè)置成 1970 年 1 月 1 日 00:00:01。max
設(shè)置Expires
頭部為 2037 年 12 月 31 日 23:59:59,設(shè)置Cache-Control
的最大存活時間為 10 年- 沒有
@
前綴的時間意味著這是一個與瀏覽器訪問時間有關(guān)的過期時間??梢灾付ㄒ粋€負值的時間,就會把 Cache-Control 頭部設(shè)置成 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
表示一年六個月。
注意,要是你用一個在將來很久才會過期的頭部,當(dāng)組件修改時你就要改變組件的文件名。因此給文件指定版本是一個不錯的方法。例如,如果你有個 javascript.js 文件 并且你要修改它,你可以在修改的文件名字后面添加一個版本號。這樣瀏覽器就要下載這個文件,如果你沒有更改文件名,瀏覽器將從緩存里面加載(舊的)文件。
除了把基于瀏覽器訪問時間設(shè)置 Expires
頭部(比如 expires 10d
)之外,也可以通過在時間前面的 modified
關(guān)鍵字,將 Expires
頭部的基準設(shè)為文件修改的時間(請注意這僅僅對存儲在硬盤的實際文件有效)。
expires modified 10d;
3 測試
要測試你的配置是否有效,可以用火狐瀏覽器的開發(fā)者工具中的網(wǎng)絡(luò)分析功能,然后用火狐訪問一個靜態(tài)文件(比如一張圖片)。在輸出的頭部信息里,應(yīng)該能看到 Expires
頭部和有 max-age
標記的 Cache-Control
頭部(max-age
標記包含了一個以秒為單位的值,比如 31536000 就是指今后的一年)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Nginx域名轉(zhuǎn)發(fā)https訪問的實現(xiàn)
這篇文章主要介紹了Nginx域名轉(zhuǎn)發(fā)https訪問的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10Nginx配置參數(shù)中文說明詳解(負載均衡與反向代理)
最近在看高性能Linux服務(wù)器構(gòu)建實戰(zhàn)的Nginx章節(jié),對其nginx介紹的非常詳細,現(xiàn)把經(jīng)常用到的Nginx配置參數(shù)中文說明摘錄和nginx做負載均衡的本人真實演示實例抄錄下來以便以后查看2020-03-03Nginx防止直接用IP訪問Web服務(wù)器的設(shè)置方法
看了很多Nginx的配置,好像都忽略了ip直接訪問Web的問題,這樣理論上不利于SEO優(yōu)化,所以我們希望可以避免直接用IP訪問網(wǎng)站,而是域名訪問,具體怎么做呢,看下面2012-09-09nginx服務(wù)器中access_log日志分析與配置詳解
通過訪問日志,可以知曉用戶的地址,網(wǎng)站的哪些部分最受歡迎,用戶的瀏覽時間,對大多數(shù)用戶用的的瀏覽器做出針對性優(yōu)化。下面這篇文章主要給大家介紹了關(guān)于nginx服務(wù)器中access_log日志分析與配置的相關(guān)資料,需要的朋友可以參考下。2017-12-12阿里云Linux系統(tǒng)Nginx配置多個域名的方法詳解
本篇文章主要介紹了阿里云Linux系統(tǒng)Nginx配置多個域名的方法詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02