搜尋
首頁運維NginxNginx如何自訂記錄及啟用日誌緩衝區

存取日誌

nginx 在處理請求後立即在存取日誌中寫入有關客戶端請求的資訊。預設情況下,存取日誌位元 logs/access.log 中,訊息以預先定義的組合格式寫入日誌。

想要精確記錄存取信息,就需要自訂一個更完整的存取日誌格式,如下所示:

http {
  log_format geoproxy
  '[$time_local] $remote_addr '
  '$realip_remote_addr $remote_user '
  '$request_method $server_protocol '
  '$scheme $server_name $uri $status '
  '$request_time $body_bytes_sent '
  '$geoip_city_country_code3 $geoip_region '
  '"$geoip_city" $http_x_forwarded_for '
  '$upstream_status $upstream_response_time '
  '"$http_referer" "$http_user_agent"';
  ...
}

這個日誌配置被命名為geoproxy,它使用許多nginx 變數來示範nginx 日誌記錄功能。詳細講解設定選項中各變數的特定意義:

當使用者發起請求時,會記錄伺服器時間 $time_local , $remote_user 值為通過基本授權的使用者名稱;

用於nginx處理 geoip_proxy 和 realip_header 指令的開啟連線的ip 位址與用戶端ip 位址;

之後記錄http 要求方法 $request_method 、協定 $server_protocol 和http 方法 $scheme:http 或#httpshttps ;# #https ;# 當然還有伺服器名稱 $server_name 、請求的uri 和回應狀態碼;

除基本資訊外,還有一些統計的結果資料:包含請求處理的毫秒時間 $request_time 、伺服器回應的資料區塊大小 $body_bytes_sent ;

此外,客戶端所在國家 $geoip_city_country_code3 、地區 $geoip_region 和城市資訊 $geoip_city 也被記錄在內;

# $http_x_forwarded_for 是用來記錄它代理伺服器來記錄

 $http_x_forwarded_for 是由它發起它代理伺服器來記錄

 $http_x_forwarded_for 是由它發起它代理伺服器來記錄

 $http_x_forwarded_for 是由它發起它代理伺服器來記錄

 $http_x_forwarded_for 來記錄。的請求的 x-forwarded-for 頭訊息;

upstream 模組中一些資料也被記錄到日誌中:被代理伺服器的回應狀態碼 $upstream_status 、建立連結和從上游伺服器接收回應主體最後一個位元組的時間 $upstream_response_time 、 建立和上游伺服器的連結時間 $upstream_connect_time 、建立連結和從上游回應頭的第一個位元組的時間 $upstream_header_time 。

請求來源 $http_referer 和使用者代理 $http_user_agent 也可以記錄在日誌中;

nginx 的日誌記錄功能非常強大且靈活的,需要注意的是: 用來定義日誌格式的 log_format 指令僅適用於 http 區塊級指令內,所有時間值均以毫秒為單位,以毫秒解析度進行測量。 。

這個格式的日誌配置將產生如下類型的日誌:



[25/feb/2019:16:20:42 0000] 10.0.1.16 192.168.0.122 derek
get http/1.1 http  / 200 0.001 370 usa mi

"ann arbor" - 200 0.001 "-" "curl/7.47.0"

#如果需要使用這個日誌設定,需要結合使用 access_log 指令, access_log 指令接收一個日誌目錄和使用的設定名作為參數:

server {
  access_log /var/log/nginx/access.log geoproxy;
  ...
}

access_log 能在多個情境中使用,每個情境中可以定義各自的日誌目錄和日誌記錄格式。

結論:nginx 中的日誌模組允許為不同的場景配置日誌格式,以便查看不同的日誌檔案。

在實際運用中,為不同上下文配置不同的日誌會非常有用,記錄的日誌內容可以簡單的信息,也可以詳細記錄所有必要信息。不僅如此,日誌內容除了支援文字

也能記錄 json 格式和 xml 格式資料。實際上 nginx 日誌有助於您了解伺服器流量、客戶端使用情況和客戶端來源等資訊。此外,存取日誌還可以幫助您定位與上游伺服器或特定 uri 相關的回應和問題;對於測試來講,存取日誌同樣有用,它可以用於分析流量情況,模擬真實的使用者互動場景。日誌在故障排除、調試、應用分析及業務調整中作用是不可或缺的。
錯誤日誌

為了精確定位nginx 的錯誤日誌,使用自帶的 error_log 指令定義錯誤日誌目錄及記錄錯誤日誌的等級,並設定如下:

error_log /var/log/nginx/error.log warn;

error_log 指令配置時需要一個必選的日誌目錄和一個可選的錯誤等級選項。

除 if 指令外, error_log 指令能在所有的上下文中使用。錯誤日誌等級包括:

debug、info、notice、warn、error、crit、alert 和 emerg。給出的日誌

等級順序就是記錄最小到最嚴謹的日誌等級順序。要注意的是 debug 日誌

需要在編譯 nginx 伺服器時,帶上 --with-debug 標識才能使用。

當伺服器配置出錯時,首先需要查看錯誤日誌以定位問題。錯誤日誌

###也是定位應用程式伺服器(如 fastcgi 服務)的利器。透過錯誤日誌,我們可以偵錯 worker 進程連線錯誤、記憶體分配、客戶端 ip 和 應用程式伺服器等問題。 錯誤日誌格式不支援自訂日誌格式 ;但他同樣記錄目前時間、日誌等級和特定資訊等資料。 ###

注意:错误日志的默认设置适用于全局。要覆盖它,请将 error_log 指令放在 main (顶级)配置上下文中。 error_log 在开源 nginx 1.5.2 版中添加了在同一配置级别指定多个指令的功能。

通过 syslog 将日志发送到统一服务器

既然不再需要将日志写到磁盘的某个目录,而是发送到统一的日志服务器,则将原有的目录部分替换为服务器 ip 即可,配置如下:

error_log syslog:server=10.0.1.42 debug;
access_log syslog:server=10.0.1.42,tag=nginx,severity=info geoproxy;

#error_log server=unix:/var/log/nginx.sock debug;
#access_log syslog:server=[2001:db8::1]:1234,facility=local7,tag=nginx,severity=info;

error_log 和 access_log 指令的 syslog 参数紧跟冒号 : 和一些参数选项。包括:必选的 server 标记表示需要连接的 ip、dns 名称或 unix 套接字;

可以使用如上注释的高端玩。

可选参数有 facility 、 severity 、 tag :

server 参数接收带端口的 ip 地址或 dns 名称;默认是 udp 514 端口。

facility 参数设置 syslog 的类型 facility ,值是 syslog rfc 标准定义的 23 个值中一个,默认值为 local7 。其他可能的值是: auth , authpriv , daemon , cron , ftp , lpr , kern , mail , news , syslog , user , uucp , local0 ... local7

tag 参数表示日志文件中显示时候的标题,默认值是 nginx 。

severity 设置消息严重程度,默认是 info 级别日志。

日志缓冲区

当系统处于负载状态时,启用日志缓冲区以降低 nginx worker 进程阻塞。大量的磁盘读写和 cpu 资源使用对于服务器资源也是一种巨大消耗。将日志数据缓冲到内存中可能是很小的一个优化手段, buffer 参数意义是缓冲区的大小,功能是当缓冲区已经写满时,日志会被写入文件中; flush 参数意义是缓冲区内日志在缓冲区内存中保存的最长时间,功能即当缓存中的日志超过最大缓存时间,也会被写入到文件中, 不足的地方即写入到日志文件的日志有些许延迟,即时调试中应当关闭日志缓冲。 。配置如下:

http {
  access_log /var/log/nginx/access.log main buffer=32k flush=1m;
}

以上是Nginx如何自訂記錄及啟用日誌緩衝區的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
NGINX單元與其他應用程序服務器NGINX單元與其他應用程序服務器Apr 24, 2025 am 12:14 AM

NGINXUnit優於ApacheTomcat、Gunicorn和Node.js內置HTTP服務器,適用於多語言項目和動態配置需求。 1)支持多種編程語言,2)提供動態配置重載,3)內置負載均衡功能,適合需要高擴展性和可靠性的項目。

NGINX單元:架構及其工作原理NGINX單元:架構及其工作原理Apr 23, 2025 am 12:18 AM

NGINXUnit通過其模塊化架構和動態重配置功能提高了應用的性能和可管理性。 1)模塊化設計包括主控進程、路由器和應用進程,支持高效管理和擴展。 2)動態重配置允許在運行時無縫更新配置,適用於CI/CD環境。 3)多語言支持通過動態加載語言運行時實現,提升了開發靈活性。 4)高性能通過事件驅動模型和異步I/O實現,即使在高並發下也保持高效。 5)安全性通過隔離應用進程提高,減少應用間相互影響。

使用NGINX單元:部署和管理應用程序使用NGINX單元:部署和管理應用程序Apr 22, 2025 am 12:06 AM

NGINXUnit可用於部署和管理多種語言的應用。 1)安裝NGINXUnit。 2)配置它以運行不同類型的應用,如Python和PHP。 3)利用其動態配置功能進行應用管理。通過這些步驟,你可以高效地部署和管理應用,提升項目效率。

NGINX與Apache:Web服務器的比較分析NGINX與Apache:Web服務器的比較分析Apr 21, 2025 am 12:08 AM

NGINX更适合处理高并发连接,而Apache更适合需要复杂配置和模块扩展的场景。1.NGINX以高性能和低资源消耗著称,适合高并发。2.Apache以稳定性和丰富的模块扩展闻名,适合复杂配置需求。

NGINX單元的優勢:靈活性和性能NGINX單元的優勢:靈活性和性能Apr 20, 2025 am 12:07 AM

NGINXUnit通過其動態配置和高性能架構提升應用的靈活性和性能。 1.動態配置允許在不重啟服務器的情況下調整應用配置。 2.高性能體現在事件驅動和非阻塞架構以及多進程模型上,能夠高效處理並發連接和利用多核CPU。

NGINX與Apache:性能,可伸縮性和效率NGINX與Apache:性能,可伸縮性和效率Apr 19, 2025 am 12:05 AM

NGINX和Apache都是強大的Web服務器,各自在性能、可擴展性和效率上有獨特的優勢和不足。 1)NGINX在處理靜態內容和反向代理時表現出色,適合高並發場景。 2)Apache在處理動態內容時表現更好,適合需要豐富模塊支持的項目。選擇服務器應根據項目需求和場景來決定。

終極攤牌:nginx vs. apache終極攤牌:nginx vs. apacheApr 18, 2025 am 12:02 AM

NGINX適合處理高並發請求,Apache適合需要復雜配置和功能擴展的場景。 1.NGINX採用事件驅動、非阻塞架構,適用於高並發環境。 2.Apache採用進程或線程模型,提供豐富的模塊生態系統,適合複雜配置需求。

nginx行動:示例和現實應用程序nginx行動:示例和現實應用程序Apr 17, 2025 am 12:18 AM

NGINX可用於提升網站性能、安全性和可擴展性。 1)作為反向代理和負載均衡器,NGINX可優化後端服務和分擔流量。 2)通過事件驅動和異步架構,NGINX高效處理高並發連接。 3)配置文件允許靈活定義規則,如靜態文件服務和負載均衡。 4)優化建議包括啟用Gzip壓縮、使用緩存和調整worker進程。

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

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具