我从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的配置参数,但似乎不起作用。
先谢谢你的帮助。
.....................................
1条答案
按热度按时间91zkwejq1#
NGINX会话日志
指令
session_log
来自http_session_log module,在其文档中提到了该指令:启用指定会话日志的使用。特殊值off取消从上一配置级别继承的session_log指令的效果。
还有更多的指令,如:
NGINX完整构建和/或动态模块
有“许多”方法可以用自定义/“所有”模块构建nginx,您应该通过研究它们的工作方式来获得成功,但是您应该已经能够“仅仅启用”它