搜尋
首頁運維NginxNginx靜態檔案服務如何設定及最佳化

根目錄和索引檔案

root 指令指定將用於搜尋檔案的根目錄。為了取得所請求檔案的路徑,nginx 將請求 uri 附加到 root 指令指定的路徑。該指令可以放在 http {} , server {} 或 location {} 上下文中的任何層級。在下面的範例中,為虛擬伺服器定義了 root 指令。它適用於未包含根指令的所有location {} 區塊,以明確重新定義根:

server {
  root /www/data;

  location / {
  }

  location /images/ {
  }

  location ~ \.(mp3|mp4) {
    root /www/media;
  }
}

#在這裡,nginx 針對/images/ 開頭的uri 將在檔案系統的/www/ data/images / 目錄中搜尋相應檔案。如果 uri 以 .mp3 或 .mp4 副檔名結尾,則 nginx 會在 /www/media/ 目錄中搜尋該文件,因為它是在匹配的位置區塊中定義的。

如果請求以 / 結尾,則 nginx 將其視為對目錄的請求,並嘗試在目錄中尋找索引檔案。 index 指令定義索引檔案的名稱(預設值為 index.html)。若要繼續該範例,如果請求 uri 是 /images/some/path/ ,則 nginx 會傳回檔案 /www/data/images/some/path/index.html (如果存在)。如果沒有,nginx 預設回傳 http 404 錯誤(未找到)。要設定 nginx 以傳回自動產生的目錄列表,請在 autoindex 指令中包含 on 參數:

location /images/ {
  autoindex on;
}

你可以在 index 指令中列出多個檔案名稱。 nginx按指定的順序搜尋檔案並傳回它找到的第一個檔案。

location / {
  index index.$geo.html index.htm index.html;
}

這裡使用的 $geo 變數是透過 geo 指令設定的自訂變數。變數的值取決於客戶端的 ip 位址。

要返回索引文件,nginx 會檢查它是否存在,然後對透過將索引文件的名稱附加到基礎 uri 上獲得的新 uri 進行內部重定向。內部重定向導致對位置的新搜索,並且可能最終位於另一個位置,如下例所示:

location / {
  root /data;
  index index.html index.php;
}

location ~ \.php {
  fastcgi_pass localhost:8000;
  #...

}

這裡,如果請求中的uri 是/path/ ,並且/data/path/index .html 不存在但/data/path/index.php 存在,則內部重定向到/path/index.php 將會對應到第二個位置。結果,請求被代理。

嘗試幾種選擇

try_files 指令可用於檢查指定的檔案或目錄是否存在; nginx 會進行內部重定向,如果沒有,則傳回指定的狀態代碼。例如,若要檢查對應於請求uri 的檔案是否存在,請使用try_files 指令和$uri 變量,如下所示:

server {
  root /www/data;

  location /images/ {
    try_files $uri /images/default.gif;
  }
}

該檔案以uri 的形式指定,使用在目前位置或虛擬伺服器的上下文中設定的根或別名指令進行處理。在這種情況下,如果對應於原始 uri 的檔案不存在,nginx 會將內部重定向到最後一個參數指定的 uri,並傳回 /www/data/images/default.gif 。

最後一個參數也可以是狀態代碼(直接以等號開頭)或位置名稱。在下列範例中,如果 try_files 指令的所有參數都不會解析為現有檔案或目錄,則會傳回 404 錯誤。

location / {
  try_files $uri $uri/ $uri.html =404;
}

在下一個範例中,如果原始uri 和附加尾部斜線的uri 都不會解析為現有檔案或目錄,則會將請求重定向到指定位置,並將其傳遞給代理伺服器。

location / {
  try_files $uri $uri/ @backend;
}

location @backend {
  proxy_pass http://backend.example.com;
}

優化服務內容的效能

載入速度是提供任何內容的關鍵因素。對 nginx 配置進行微小最佳化可以提高生產力並幫助實現最佳效能。

啟用 sendfile

預設情況下,nginx 會自行處理檔案傳輸,並在傳送之前將檔案複製到緩衝區中。啟用 sendfile 指令消除了將資料複製到緩衝區的步驟,並允許將資料從一個檔案描述符直接複製到另一個檔案描述符。或者,為了防止一個快速連線完全佔用工作進程,可以使用sendfile_max_chunk 指令限制單一sendfile() 呼叫中傳輸的資料量(在本例中為1 mb):

location /mp3 {
  sendfile      on;
  sendfile_max_chunk 1m;
  #...

}

啟用tcp_nopush

將tcp_nopush 指令與sendfile on; 指令一起使用。這使得 nginx 可以在 sendfile() 取得資料區塊之後立即在一個資料包中傳送 http 回應頭。

location /mp3 {
  sendfile  on;
  tcp_nopush on;
  #...

}

啟用 tcp_nodelay

tcp_nodelay 指令允許覆蓋 nagle 的演算法 ,該演算法最初設計用於解決慢速網路中小封包的問題。該演算法將許多小資料包合併為一個較大的資料包,並以 200 毫秒的延遲發送資料包。如今,在提供大型靜態檔案時,無論資料包大小如何,都可以立即發送資料。延遲也會影響線上應用程式(ssh,線上遊戲,線上交易等)。預設情況下, tcp_nodelay 指令設定為 on,這表示禁用了 nagle的演算法。此指令僅用於 keepalive 連線:

location /mp3 {
  tcp_nodelay    on;
  keepalive_timeout 65;
  #...
  
}

最佳化積壓佇列

其中一个重要因素是 nginx 可以多快地处理传入连接。一般规则是在建立连接时,将其放入侦听套接字的 "listen" (监听)队列中。在正常负载下,队列很小或根本没有队列。但是在高负载下,队列会急剧增长,导致性能不均匀,连接中断,延迟增加。

显示积压队列使用命令 netstat -lan 来显示当前监听队列。输出可能如下所示,它显示在端口 80上的监听队列中,有 10 个未接受的连接,这些连接针对配置的最多 128 个排队连接。这种情况很正常。

current listen queue sizes (qlen/incqlen/maxqlen)
listen     local address     
0/0/128    *.12345      
10/0/128    *.80    
0/0/128    *.8080

相反,在以下命令中,未接受的连接数(192)超过了 128 的限制。当网站流量很大时,这种情况很常见。要获得最佳性能,需要在操作系统和 nginx 配置中增加可以排队等待 nginx 接受的最大连接数。

current listen queue sizes (qlen/incqlen/maxqlen)
listen     local address     
0/0/128    *.12345      
192/0/128    *.80    
0/0/128    *.8080

调整操作系统

将 net.core.somaxconn 内核参数的值从其默认值(128)增加到足以容纳大量流量的值。在这个例子中,它增加到 4096。

  • freebsd 的命令为 sudo sysctl kern.ipc.somaxconn=4096

  • linux 的命令为 1. sudo sysctl -w net.core.somaxconn=4096 2. 将 net.core.somaxconn = 4096 加入到 /etc/sysctl.conf 文件中。

调整 nginx

如果将 somaxconn 内核参数设置为大于 512 的值,请将 backlog 参数增加在 nginx listen 指令以匹配修改:

server {
  listen 80 backlog=4096;
  # ...

}

以上是Nginx靜態檔案服務如何設定及最佳化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
NGINX的優點:速度,效率和控制NGINX的優點:速度,效率和控制May 12, 2025 am 12:13 AM

NGINX受歡迎的原因是其在速度、效率和控制方面的優勢。 1)速度:採用異步、非阻塞處理,支持高並發連接,靜態文件服務能力強。 2)效率:內存使用低,負載均衡功能強大。 3)控制:通過靈活的配置文件管理行為,模塊化設計便於擴展。

NGINX與Apache:社區,支持和資源NGINX與Apache:社區,支持和資源May 11, 2025 am 12:19 AM

NGINX和Apache在社區、支持和資源方面的差異如下:1.NGINX的社區雖然規模較小,但活躍度和專業性高,官方支持通過NGINXPlus提供高級功能和專業服務。 2.Apache擁有龐大且活躍的社區,官方支持主要通過豐富的文檔和社區資源提供。

NGINX單元:應用程序服務器簡介NGINX單元:應用程序服務器簡介May 10, 2025 am 12:17 AM

NGINXUnit是一個開源的應用服務器,支持多種編程語言和框架,如Python、PHP、Java、Go等。 1.它支持動態配置,可以在不重啟服務器的情況下調整應用配置。 2.NGINXUnit支持多語言應用,簡化了多語言環境的管理。 3.通過配置文件,可以輕鬆部署和管理應用,如運行Python和PHP應用。 4.它還支持高級配置,如路由和負載均衡,幫助管理和擴展應用。

使用NGINX:優化網站性能和可靠性使用NGINX:優化網站性能和可靠性May 09, 2025 am 12:19 AM

NGINX可通过以下方式提升网站性能和可靠性:1.作为Web服务器处理静态内容;2.作为反向代理服务器转发请求;3.作为负载均衡器分配请求;4.作为缓存服务器减轻后端压力。通过配置优化如启用Gzip压缩和调整连接池,NGINX能显著提高网站性能。

NGINX的目的:服務Web內容等NGINX的目的:服務Web內容等May 08, 2025 am 12:07 AM

nginxserveswebcontentandactsasareverseproxy,loadBalancer和more.1)效率高效的servesstaticContentLikeHtmlandImages.2)itfunctionsasareverseproxybalancer,and andginxenhanceperforfforfforfforfforfforffrenfcaching.4)

NGINX單元:簡化應用程序部署NGINX單元:簡化應用程序部署May 07, 2025 am 12:08 AM

NGINXUnit通過動態配置和多語言支持簡化應用部署。 1)動態配置無需重啟服務器即可修改。 2)支持多種編程語言,如Python、PHP、Java。 3)採用異步非阻塞I/O模型,提升高並發處理性能。

NGINX的影響:Web服務器及其他NGINX的影響:Web服務器及其他May 06, 2025 am 12:05 AM

NGINX起初解決C10K問題,現已發展為處理負載均衡、反向代理和API網關的全能選手。 1)它以事件驅動和非阻塞架構聞名,適合高並發。 2)NGINX可作為HTTP和反向代理服務器,支持IMAP/POP3。3)其工作原理基於事件驅動和異步I/O模型,提升了性能。 4)基本用法包括配置虛擬主機和負載均衡,高級用法涉及復雜負載均衡和緩存策略。 5)常見錯誤包括配置語法錯誤和權限問題,調試技巧包括使用nginx-t命令和stub_status模塊。 6)性能優化建議包括調整worker參數、使用gzip壓縮和

NGINX故障排除:診斷和解決常見錯誤NGINX故障排除:診斷和解決常見錯誤May 05, 2025 am 12:09 AM

Nginx常見錯誤的診斷與解決方法包括:1.查看日誌文件,2.調整配置文件,3.優化性能。通過分析日誌、調整超時設置和優化緩存及負載均衡,可以有效解決404、502、504等錯誤,提高網站穩定性和性能。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具