接口列表

核心文件ngx_log.h

主要接口如下:

ngx_log_error(level, log, err, fmt, ...)

ngx_log_debug(level, log, err, fmt, ...)

ngx_log_debug0(level, log, err, fmt)

ngx_log_debug1(level, log, err, fmt, arg1)

ngx_log_debug2(level, log, err, fmt, arg1, arg2)

ngx_log_debug3(level, log, err, fmt, arg1, arg2, arg3)

ngx_log_debug4(level, log, err, fmt, arg1, arg2, arg3, arg4)

ngx_log_debug5(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5)

ngx_log_debug6(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6)

ngx_log_debug7(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6, arg7)

ngx_log_debug8(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)

可以简单分成三组

ngx_log_error(level, log, err, fmt, ...)

ngx_log_debug(level, log, err, fmt, ...)

ngx_log_debugX(level, log, err, fmt, ...)

ngx_log_error接口

ngx_log_error(level, log, err, fmt, ...) 标准的分级打印接口。

第1个参数level可选宏如下:

  1. #define NGX_LOG_STDERR 0
  2. #define NGX_LOG_EMERG 1
  3. #define NGX_LOG_ALERT 2
  4. #define NGX_LOG_CRIT 3
  5. #define NGX_LOG_ERR 4
  6. #define NGX_LOG_WARN 5
  7. #define NGX_LOG_NOTICE 6
  8. #define NGX_LOG_INFO 7
  9. #define NGX_LOG_DEBUG 8

打印等级通过nginx.conf中的error_log指令可以配置,其中WARN以上级别打印会直接打印到stderr上,对于某些临时调试场景有意义。

第2个参数log,用于部分回调功能。(还未深入研究)【个人认为此参数应该以全局变量方式存在,不应该设置为参数,影响在算法模块中使用日志】

常见获取方式包括

  1. [ngx_conf_t].log
  2. [ngx_http_request_t].connection.log
  3. [ngx_connection_t].log

第3个参数err,用于记录errno,非系统调用错误,一般使用0即可。【个人认为此参数过设计】

后续参数为可变长的字符串参数,其中针对ngx常用的几个类型有特殊定义,可以参考下文中的表格。

使用示例:

  1. static void*
  2. ngx_http_mytest_create_srv_conf(ngx_conf_t *cf)
  3. {
  4. ...
  5. ngx_log_error(NGX_LOG_ALERT, cf->log, 0, "ngx_http_mytest_create_srv_conf");
  6. ...
  7. }
  8. static ngx_int_t
  9. ngx_http_ws_cache_info_filter(ngx_http_request_t *r)
  10. {
  11. ...
  12. ngx_log_error(NGX_LOG_WARN, r->connection->log, 0, "ws_cache_info context already exist!");
  13. ...
  14. }

ngx_log_debug接口

第一个参数,实际上为模块类型标识,会与log->log_level进行比对,如果比对失败将不进行打印。

进行打印时功能等价于ngx_log_error的NGX_LOG_DEBUG级别,后续参数含义也一致。

  1. #define NGX_LOG_DEBUG_CORE 0x010
  2. #define NGX_LOG_DEBUG_ALLOC 0x020
  3. #define NGX_LOG_DEBUG_MUTEX 0x040
  4. #define NGX_LOG_DEBUG_EVENT 0x080
  5. #define NGX_LOG_DEBUG_HTTP 0x100
  6. #define NGX_LOG_DEBUG_MAIL 0x200
  7. #define NGX_LOG_DEBUG_STREAM 0x400

注意:ngx_log_debug接口并不在NGX_DEBUG宏限制范围内,也就是说即使编译时没有添加--debug参数,ngx_log_debug接口依然可以使用。

【个人认为:level参数没有意义应该删除,接口应该放在NGX_DEBUG宏限制范围内,与ngx_log_debugX语义保持一致】

使用示例:

  1. static ngx_int_t
  2. ngx_http_ws_cache_info_filter(ngx_http_request_t *r)
  3. {
  4. ...
  5. ngx_log_debug(NGX_LOG_DEBUG_HTTP, r->connection->log, 0, "enter ngx_http_ws_cache_info_filter");
  6. ...
  7. }

ngx_log_debugX接口

用于固定数量参数的打印接口,参数与ngx_log_debug一致,接口定义在NGX_DEBUG宏限制范围内,即必须在编译时开启--debug参数,这组接口才能使用。

【个人认为:ngx_log_debugX接口本意应该为了不支持动态数量参数的C编译器设计的,一般通途不大,但它时唯一一组可以通过编译参数去除的调试接口,所以还有广泛使用。根因还是ngx_log_debug接口设计不合理】

使用示例:

  1. static ngx_int_t
  2. ngx_http_ws_cache_info_variable(ngx_http_request_t *r, ngx_http_variable_value_t *v, uintptr_t data)
  3. {
  4. ...
  5. ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0, "arg_name=%V", &arg_name);
  6. ...
  7. }

ngx特殊格式化

标识符 对应类型
%O off_t
%T time_t
%z ssize_t
%i ngx_int_t
%p void *
%V ngx_str_t *
%s u_char * (null-terminated)
%*s size_t + u_char *

更多完成的标识符可以参考《深入理解Nginx(第2版)》P148 表4-8

nginx开发_调试日志的更多相关文章

  1. nginx开发_配置项

    nginx开发笔记_配置项 模块的配置项即nginx.conf中的指令,HTTP模块指令可以分为三个级别: main级,直接写在http{}块中的指令 server级,写在server{}块中的指令 ...

  2. nginx开发_字符串操作函数

    由于ngx_str_t为非NULL结尾的函数,且网络请求中有大量忽略大小写的需求,所以nginx内部封装了许多字符串操作相关的函数,函数名称极其相识,且使用时有有些约定,特此整理. 赋值&拷贝 ...

  3. Android开发调试日志工具类[支持保存到SD卡]

    直接上代码: package com.example.callstatus; import java.io.File; import java.io.FileWriter; import java.i ...

  4. Arcgis Runtime 100.3开发实例源代码调试日志

    Arcgis Runtime 100.3开发实例源代码调试日志 路径: "D:\arcgis runtime1003\arcgis-runtime-samples-dotnet-master ...

  5. nginx 学习笔记(5) nginx调试日志

    为启动一个调试日志,nginx需要在构建时配置城支持调试模式. ./configure --with-debug ... 而且调试级别应该使用err_log指令来设置: err_log /path/t ...

  6. Nginx开发从入门到精通 学习目录分享学习 (阿里著作)

    Nginx开发从入门到精通   缘起 nginx由于出色的性能,在世界范围内受到了越来越多人的关注,在淘宝内部它更是被广泛的使用,众多的开发以及运维同学都迫切的想要了解nginx模块的开发以及它的内部 ...

  7. nginx自动切割访问日志

    Web 访问日志 (access_log) 记录了所有外部客户端对Web服务器的访问行为,包含了客户端IP,访问日期,访问的URL资源,服务器返回的HTTP状态码等重要信息. 一条典型的Web访问日志 ...

  8. 关于调试日志Log

    __VA_ARGS__  是一个可变参数的宏,这个可变参数的宏是新的C99规范中新增的,目前似乎只有gcc支持(VC6.0的编译器不支持).宏前面加上##的作用在于,当可变参数的个数为0时,这里的## ...

  9. Nginx 基本配置和日志分析

    最近在维护的一个项目,路由转发规则都统一通过Nginx转发,所以再次参考部分博文和书本,熟悉Nginx的基本配置,还有一个重点也是日志的分析 Nginx 常用模块是server块,location块. ...

随机推荐

  1. ajax中没法用response下载文件啊

    ajax 下载不太现实第一,http 不支持直接的二进制传输,二进制数据需要编码 例如base64 ,这点服务器端可以实现第二,客户端获得编码后的文件要转换,js应该也可以第三点,最为致命,js无法操 ...

  2. luogu P1704 寻找最优美做题曲线

    题目背景 nodgd是一个喜欢写程序的同学,前不久(好像还是有点久了)洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题.于是发生了一系列有趣的事情,他就打算用这些事情来出题恶心大家-- 题 ...

  3. CodeBlock换肤

    CodeBlock换肤 conf文件下载地址 我的是在D:\Program Files (x86)\CodeBlocks\AppData\codeblocks\default.conf 然后替换本地的 ...

  4. 前端进阶之路:初涉Less

    阅读目录 一.Less介绍 1.官方介绍 2.自己理解 3.Less.Sass.Stylus 二.Less使用入门 1.开发模式下使用Less 2.运行模式下使用Less 三.常见用法示例 1.从第一 ...

  5. Java主线程等待所有子线程执行完毕再执行解决办法(转)

    方法一: Thread.join()方法,亲测可行,thread.join()方法 Vector<Thread> ts = new Vector<Thread>(); for  ...

  6. java开始到熟悉61

    本此主题:多维数组----矩阵运算 矩阵的运算规则是将对应位置的值进行运算,如上图所示. package array; public class Matrix { /** * 打印矩阵 * @para ...

  7. Ubuntu 16.04 LTS安装Eclipse配置Pydev

    原材料: 下载 jdk-8u121-linux-x64.tar.gz 下载 eclipse-jee-neon-2-linux-gtk-x86_64.tar.gz 1.安装jdk sudo mkdir ...

  8. Nova虚拟机迁移

    这里根据我的配置环境只讲述冷迁移(Migrate Instance)需要进行的计算节点配置而不包含热迁移(Live Migrate Instance),后者需要共享存储及Hypervisor的支持. ...

  9. openwrt gstreamer实例学习笔记(二.gstreamer 的 Element)

    对程序员来说,GStreamer 中最重要的一个概念就是 GstElement 对象.该对象是构建一个媒体管道的基本块.所有上层(high-level)部件都源自GstElement对象.任何一个解码 ...

  10. mac classpath设置

    I've been searching for the answer daylong, and finally had the problems solved. I am going to write ...