关于Nginx 1.22-稳定源代码构建,如何启用所有原始包含模块?特别是“ngx_http_log_module”

d5vmydt9  于 2023-03-17  发布在  Nginx
关注(0)|答案(1)|浏览(196)

我从https://nginx.org/en/download.html下载了nginx-1.22.1.tar.gz,并打算配置“ngx_http_log_module”的http模块用于日志分析,但不幸的是,该模块似乎没有按我预期的方式工作。
源码包中原来包含的http模块如下:

[root@centos-7-2 nginx-1.22.1]# ls -al src/http/modules/
total 1712
drwxr-xr-x 3 1001 1001   4096 Mar 12 20:24 .
drwxr-xr-x 4 1001 1001   4096 Mar 12 20:24 ..
-rw-r--r-- 1 1001 1001  11866 Oct 19 16:02 ngx_http_access_module.c
-rw-r--r-- 1 1001 1001   6994 Oct 19 16:02 ngx_http_addition_filter_module.c
-rw-r--r-- 1 1001 1001  11742 Oct 19 16:02 ngx_http_auth_basic_module.c
-rw-r--r-- 1 1001 1001  11525 Oct 19 16:02 ngx_http_auth_request_module.c
-rw-r--r-- 1 1001 1001  31112 Oct 19 16:02 ngx_http_autoindex_module.c
-rw-r--r-- 1 1001 1001  19921 Oct 19 16:02 ngx_http_browser_module.c
-rw-r--r-- 1 1001 1001  41078 Oct 19 16:02 ngx_http_charset_filter_module.c
-rw-r--r-- 1 1001 1001   8737 Oct 19 16:02 ngx_http_chunked_filter_module.c
-rw-r--r-- 1 1001 1001  32273 Oct 19 16:02 ngx_http_dav_module.c
-rw-r--r-- 1 1001 1001   6240 Oct 19 16:02 ngx_http_degradation_module.c
-rw-r--r-- 1 1001 1001   5536 Oct 19 16:02 ngx_http_empty_gif_module.c
-rw-r--r-- 1 1001 1001 113329 Oct 19 16:02 ngx_http_fastcgi_module.c
-rw-r--r-- 1 1001 1001   6426 Oct 19 16:02 ngx_http_flv_module.c
-rw-r--r-- 1 1001 1001  22371 Oct 19 16:02 ngx_http_geoip_module.c
-rw-r--r-- 1 1001 1001  44070 Oct 19 16:02 ngx_http_geo_module.c
-rw-r--r-- 1 1001 1001 142741 Oct 19 16:02 ngx_http_grpc_module.c
-rw-r--r-- 1 1001 1001  17038 Oct 19 16:02 ngx_http_gunzip_filter_module.c
-rw-r--r-- 1 1001 1001  29921 Oct 19 16:02 ngx_http_gzip_filter_module.c
-rw-r--r-- 1 1001 1001   8468 Oct 19 16:02 ngx_http_gzip_static_module.c
-rw-r--r-- 1 1001 1001  21700 Oct 19 16:02 ngx_http_headers_filter_module.c
-rw-r--r-- 1 1001 1001  42569 Oct 19 16:02 ngx_http_image_filter_module.c
-rw-r--r-- 1 1001 1001  15036 Oct 19 16:02 ngx_http_index_module.c
-rw-r--r-- 1 1001 1001  20585 Oct 19 16:02 ngx_http_limit_conn_module.c
-rw-r--r-- 1 1001 1001  28816 Oct 19 16:02 ngx_http_limit_req_module.c
-rw-r--r-- 1 1001 1001  49773 Oct 19 16:02 ngx_http_log_module.c
-rw-r--r-- 1 1001 1001  15012 Oct 19 16:02 ngx_http_map_module.c
-rw-r--r-- 1 1001 1001  21205 Oct 19 16:02 ngx_http_memcached_module.c
-rw-r--r-- 1 1001 1001   6794 Oct 19 16:02 ngx_http_mirror_module.c
-rw-r--r-- 1 1001 1001 118391 Oct 19 16:02 ngx_http_mp4_module.c
-rw-r--r-- 1 1001 1001   6976 Oct 19 16:02 ngx_http_not_modified_filter_module.c
-rw-r--r-- 1 1001 1001 142075 Oct 19 16:02 ngx_http_proxy_module.c
-rw-r--r-- 1 1001 1001   8973 Oct 19 16:02 ngx_http_random_index_module.c
-rw-r--r-- 1 1001 1001  26701 Oct 19 16:02 ngx_http_range_filter_module.c
-rw-r--r-- 1 1001 1001  15328 Oct 19 16:02 ngx_http_realip_module.c
-rw-r--r-- 1 1001 1001  17385 Oct 19 16:02 ngx_http_referer_module.c
-rw-r--r-- 1 1001 1001  28370 Oct 19 16:02 ngx_http_rewrite_module.c
-rw-r--r-- 1 1001 1001  61441 Oct 19 16:02 ngx_http_scgi_module.c
-rw-r--r-- 1 1001 1001   9205 Oct 19 16:02 ngx_http_secure_link_module.c
-rw-r--r-- 1 1001 1001  14029 Oct 19 16:02 ngx_http_slice_filter_module.c
-rw-r--r-- 1 1001 1001   6615 Oct 19 16:02 ngx_http_split_clients_module.c
-rw-r--r-- 1 1001 1001  79675 Oct 19 16:02 ngx_http_ssi_filter_module.c
-rw-r--r-- 1 1001 1001   2800 Oct 19 16:02 ngx_http_ssi_filter_module.h
-rw-r--r-- 1 1001 1001  39456 Oct 19 16:02 ngx_http_ssl_module.c
-rw-r--r-- 1 1001 1001   2105 Oct 19 16:02 ngx_http_ssl_module.h
-rw-r--r-- 1 1001 1001   8072 Oct 19 16:02 ngx_http_static_module.c
-rw-r--r-- 1 1001 1001   6094 Oct 19 16:02 ngx_http_stub_status_module.c
-rw-r--r-- 1 1001 1001  26018 Oct 19 16:02 ngx_http_sub_filter_module.c
-rw-r--r-- 1 1001 1001  10833 Oct 19 16:02 ngx_http_try_files_module.c
-rw-r--r-- 1 1001 1001  18728 Oct 19 16:02 ngx_http_upstream_hash_module.c
-rw-r--r-- 1 1001 1001   7555 Oct 19 16:02 ngx_http_upstream_ip_hash_module.c
-rw-r--r-- 1 1001 1001  14923 Oct 19 16:02 ngx_http_upstream_keepalive_module.c
-rw-r--r-- 1 1001 1001   8198 Oct 19 16:02 ngx_http_upstream_least_conn_module.c
-rw-r--r-- 1 1001 1001  12803 Oct 19 16:02 ngx_http_upstream_random_module.c
-rw-r--r-- 1 1001 1001   8644 Oct 19 16:02 ngx_http_upstream_zone_module.c
-rw-r--r-- 1 1001 1001  25004 Oct 19 16:02 ngx_http_userid_filter_module.c
-rw-r--r-- 1 1001 1001  75803 Oct 19 16:02 ngx_http_uwsgi_module.c
-rw-r--r-- 1 1001 1001  29999 Oct 19 16:02 ngx_http_xslt_filter_module.c
drwxr-xr-x 2 1001 1001    126 Mar 12 20:24 perl

但是当我尝试构建nginx包,然后运行nginx -V检查安装的模块时,似乎没有加载任何模块:
x一个一个一个一个x一个一个二个一个x一个一个三个一个
我真的不知道如何使用原来包含的http模块,我想使用的预期http模块是ngx_http_log_module.c,根据https://nginx.org/en/docs/http/ngx_http_session_log_module.html页面上的官方说明,以下指令无法成功使用:

server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
            session_log one;
        }
.......

# ./nginx -t
nginx: [emerg] unknown directive "session_log" in /usr/local/nginx/conf/nginx.conf:47
nginx: configuration file /usr/local/nginx/conf/nginx.conf test failed

顺便说一下,我也尝试过在./configure阶段使用--add-module的配置参数,但似乎不起作用。
先谢谢你的帮助。
.....................................

91zkwejq

91zkwejq1#

NGINX会话日志

指令session_log来自http_session_log module,在其文档中提到了该指令:

Syntax:     

session_log name | off;

Default:    off;

Context:    http, server, location

启用指定会话日志的使用。特殊值off取消从上一配置级别继承的session_log指令的效果。
还有更多的指令,如:

session_log_format name string ...;
session_log_zone path zone=name:size [format=format]

NGINX完整构建和/或动态模块

有“许多”方法可以用自定义/“所有”模块构建nginx,您应该通过研究它们的工作方式来获得成功,但是您应该已经能够“仅仅启用”它

相关问题