调试日志
| 选定客户端的调试日志 记录到循环内存缓冲区 |
要启用调试日志,需要在构建过程中配置nginx以支持调试:
./configure --with-debug ...
然后使用error_log指令设置debug级别:
error_log /path/to/log debug;
要验证nginx是否配置为支持调试,请运行nginx -V命令:
configure arguments: --with-debug ...
预先构建的Linux软件包提供了nginx-debug二进制文件(1.9.8),可以使用以下命令运行:
service nginx stop service nginx-debug start
然后设置debug级别。 Windows版本的nginx二进制文件始终构建有调试日志支持,因此只需设置debug级别即可。
请注意,重新定义日志而不指定debug级别将禁用调试日志。 在下面的示例中,重新定义服务器级别的日志将禁用此服务器的调试日志:
error_log /path/to/log debug;
http {
server {
error_log /path/to/log;
...
为了避免这种情况,要么注释掉重新定义日志的行,要么还要添加debug级别的规范:
error_log /path/to/log debug;
http {
server {
error_log /path/to/log debug;
...
选定客户端的调试日志
也可以仅为选定的客户端地址启用调试日志:
error_log /path/to/log;
events {
debug_connection 192.168.1.1;
debug_connection 192.168.10.0/24;
}
记录到循环内存缓冲区
调试日志可以写入循环内存缓冲区:
error_log memory:32m debug;
即使在高负载下,使用debug级别记录到内存缓冲区对性能也没有显著影响。在这种情况下,可以使用如下的gdb脚本提取日志:
set $log = ngx_cycle->log
while $log->writer != ngx_log_memory_writer
set $log = $log->next
end
set $buf = (ngx_log_memory_buf_t *) $log->wdata
dump binary memory debug_log.txt $buf->start $buf->end
或者使用如下的lldb脚本:
expr ngx_log_t *$log = ngx_cycle->log
expr while ($log->writer != ngx_log_memory_writer) { $log = $log->next; }
expr ngx_log_memory_buf_t *$buf = (ngx_log_memory_buf_t *) $log->wdata
memory read --force --outfile debug_log.txt --binary $buf->start $buf->end
