⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ngx_log.h

📁 Nginx是一个高性能的HTTP和反向代理服务器
💻 H
字号:
/* * Copyright (C) Igor Sysoev */#ifndef _NGX_LOG_H_INCLUDED_#define _NGX_LOG_H_INCLUDED_#include <ngx_config.h>#include <ngx_core.h>#define NGX_LOG_STDERR            0#define NGX_LOG_EMERG             1#define NGX_LOG_ALERT             2#define NGX_LOG_CRIT              3#define NGX_LOG_ERR               4#define NGX_LOG_WARN              5#define NGX_LOG_NOTICE            6#define NGX_LOG_INFO              7#define NGX_LOG_DEBUG             8#define NGX_LOG_DEBUG_CORE        0x010#define NGX_LOG_DEBUG_ALLOC       0x020#define NGX_LOG_DEBUG_MUTEX       0x040#define NGX_LOG_DEBUG_EVENT       0x080#define NGX_LOG_DEBUG_HTTP        0x100#define NGX_LOG_DEBUG_MAIL        0x200#define NGX_LOG_DEBUG_MYSQL       0x400/* * do not forget to update debug_levels[] in src/core/ngx_log.c * after the adding a new debug level */#define NGX_LOG_DEBUG_FIRST       NGX_LOG_DEBUG_CORE#define NGX_LOG_DEBUG_LAST        NGX_LOG_DEBUG_MYSQL#define NGX_LOG_DEBUG_CONNECTION  0x80000000#define NGX_LOG_DEBUG_ALL         0x7ffffff0typedef u_char *(*ngx_log_handler_pt) (ngx_log_t *log, u_char *buf, size_t len);struct ngx_log_s {    ngx_uint_t           log_level;    ngx_open_file_t     *file;    ngx_atomic_uint_t    connection;    ngx_log_handler_pt   handler;    void                *data;    /*     * we declare "action" as "char *" because the actions are usually     * the static strings and in the "u_char *" case we have to override     * their types all the time     */    char                *action;};#define NGX_MAX_ERROR_STR   2048/*********************************/#if (NGX_HAVE_GCC_VARIADIC_MACROS)#define NGX_HAVE_VARIADIC_MACROS  1#define ngx_log_error(level, log, args...)                                    \    if ((log)->log_level >= level) ngx_log_error_core(level, log, args)void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,    const char *fmt, ...);#define ngx_log_debug(level, log, args...)                                    \    if ((log)->log_level & level)                                             \        ngx_log_error_core(NGX_LOG_DEBUG, log, args)/*********************************/#elif (NGX_HAVE_C99_VARIADIC_MACROS)#define NGX_HAVE_VARIADIC_MACROS  1#define ngx_log_error(level, log, ...)                                        \    if ((log)->log_level >= level) ngx_log_error_core(level, log, __VA_ARGS__)void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,    const char *fmt, ...);#define ngx_log_debug(level, log, ...)                                        \    if ((log)->log_level & level)                                             \        ngx_log_error_core(NGX_LOG_DEBUG, log, __VA_ARGS__)/*********************************/#else /* NO VARIADIC MACROS */#define NGX_HAVE_VARIADIC_MACROS  0void ngx_cdecl ngx_log_error(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,    const char *fmt, ...);void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,    const char *fmt, va_list args);void ngx_cdecl ngx_log_debug_core(ngx_log_t *log, ngx_err_t err,    const char *fmt, ...);#endif /* VARIADIC MACROS *//*********************************/#if (NGX_DEBUG)#if (NGX_HAVE_VARIADIC_MACROS)#define ngx_log_debug0  ngx_log_debug#define ngx_log_debug1  ngx_log_debug#define ngx_log_debug2  ngx_log_debug#define ngx_log_debug3  ngx_log_debug#define ngx_log_debug4  ngx_log_debug#define ngx_log_debug5  ngx_log_debug#define ngx_log_debug6  ngx_log_debug#define ngx_log_debug7  ngx_log_debug#define ngx_log_debug8  ngx_log_debug#else /* NO VARIADIC MACROS */#define ngx_log_debug0(level, log, err, fmt)                                  \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt)#define ngx_log_debug1(level, log, err, fmt, arg1)                            \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt, arg1)#define ngx_log_debug2(level, log, err, fmt, arg1, arg2)                      \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt, arg1, arg2)#define ngx_log_debug3(level, log, err, fmt, arg1, arg2, arg3)                \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3)#define ngx_log_debug4(level, log, err, fmt, arg1, arg2, arg3, arg4)          \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4)#define ngx_log_debug5(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5)    \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4, arg5)#define ngx_log_debug6(level, log, err, fmt,                                  \                       arg1, arg2, arg3, arg4, arg5, arg6)                    \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6)#define ngx_log_debug7(level, log, err, fmt,                                  \                       arg1, arg2, arg3, arg4, arg5, arg6, arg7)              \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt,                                     \                       arg1, arg2, arg3, arg4, arg5, arg6, arg7)#define ngx_log_debug8(level, log, err, fmt,                                  \                       arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)        \    if ((log)->log_level & level)                                             \        ngx_log_debug_core(log, err, fmt,                                     \                       arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)#endif#else /* NO NGX_DEBUG */#define ngx_log_debug0(level, log, err, fmt)#define ngx_log_debug1(level, log, err, fmt, arg1)#define ngx_log_debug2(level, log, err, fmt, arg1, arg2)#define ngx_log_debug3(level, log, err, fmt, arg1, arg2, arg3)#define ngx_log_debug4(level, log, err, fmt, arg1, arg2, arg3, arg4)#define ngx_log_debug5(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5)#define ngx_log_debug6(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6)#define ngx_log_debug7(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5,    \                       arg6, arg7)#define ngx_log_debug8(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5,    \                       arg6, arg7, arg8)#endif/*********************************/ngx_log_t *ngx_log_init(void);ngx_log_t *ngx_log_create_errlog(ngx_cycle_t *cycle, ngx_array_t *args);char *ngx_set_error_log_levels(ngx_conf_t *cf, ngx_log_t *log);void ngx_log_abort(ngx_err_t err, const char *text);extern ngx_module_t  ngx_errlog_module;#endif /* _NGX_LOG_H_INCLUDED_ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -