nginx的post命令记录body到日志中

最近打算使用ELK搭建日志收集系统,前端移动端通过http请求发送日志请求到后端,后端记录日志到日志文件中,filebeat读取日志文件,推送到logstash,因为没有任何业务代码,后端的http服务器使用性能较高的nginx(springboot与netty测试结果另外在其他文章中讨论),nginx的post请求写日志费了一番周折,这里记录一下,以免后续忘记;

1、下载nginx源码:

nginx-1.12.2.tar.gz
LuaJIT-2.0.5.tar.gz
v0.10.9rc7.tar.gz

2、修改源码

因为默认nginx不支持post请求中的body写日志,所以需要通过修改源码的方式支持,见下面的链接:
https://blog.csdn.net/weixin_34115824/article/details/92984867

3、编译

编译后出现编译出错,替换v0.10.9rc7.tar.gz解决,之前用了低版本的包导致的;

4、运行时出错,用这篇文章的方法解决

https://my.oschina.net/ranhai/blog/1797454

5、中文转义字符的解决:

解决nginx访问日志记录post数据

注意:日志需要在模块中重新定义才能正常输出post的请求;

6、post命令数据的长度限制:

因为是用在日志服务器中,前端需要定时积累日志数据并采用定时发送,在发送非常大的数据的时候发现log日志中的记录为空,查了资料发现默认post请求的最大长度不够(content-lenth大概12k左右就不写日志了),修改参数 “client_body_buffer_size”
参考文章:https://blog.51cto.com/fuyuan2016/1853410

最后:

整个过程参考:https://blog.csdn.net/weixin_37519367/article/details/73498756

### 回答1: 要查看nginx接收到的post请求参数,可以通过以下几个步骤进行操作: 1. 设置nginx配置文件:修改nginx.conf文件,找到http块的server段落,并在其添加以下配置项: ``` location / { ... proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://your_backend_server; proxy_intercept_errors on; error_page 502 = @fallback; } location @fallback { internal; proxy_pass http://your_backend_server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } ``` 其,`your_backend_server`是指向后端真实服务器的地址。 2. 重新加载nginx配置:修改完配置文件后,执行以下命令重新加载配置: ``` sudo nginx -s reload ``` 3. 查看post请求参数:通过访问nginx服务器的访问地址进行post请求,例如: ``` curl -X POST -d "param1=value1&param2=value2" http://your_nginx_server ``` 其,`your_nginx_server`是指向nginx服务器的地址。这样,nginx会将post请求转发至后端真实服务器,并将请求参数一同发送过去。 在后端服务器上,可以使用相应的编程语言(如Python的Flask框架)来接收和解析post请求参数,并对其进行处理。 通过以上步骤,就可以在nginx查看post请求参数了。 ### 回答2: 要使用Nginx查看POST请求参数,你可以按照以下步骤进行操作: 1. 首先,确保你已经正确配置了Nginx的服务器块(server block)。你可以使用文本编辑器打开Nginx的配置文件,通常位于/etc/nginx/nginx.conf或/usr/local/nginx/conf/nginx.conf。 2. 在server block,找到对应的location段落并添加以下指令: ``` location /your_post_url { proxy_set_header Content-Type application/x-www-form-urlencoded; proxy_pass_request_body on; proxy_set_body $request_body; } ``` 这将设置NginxPOST请求的请求体传递给上游服务器,并将请求体的参数存储在$request_body变量。 3. 保存并关闭配置文件,然后重启Nginx服务以使配置生效。你可以使用以下命令重启Nginx: ``` sudo service nginx restart ``` 4. 现在,当有POST请求发送到Nginx时,它将将请求体数据传递给上游服务器,并将请求体的参数存储在$request_body变量。你可以在Nginx的访问日志查看这些参数。默认情况下,Nginx的访问日志位于/var/log/nginx/access.log。你可以使用以下命令查看日志文件: ``` sudo tail -f /var/log/nginx/access.log ``` 注意,这只会实时显示日志文件的最新内容。你可以通过Ctrl+C停止查看。 通过上述步骤,你可以使用Nginx查看POST请求的参数。请确保在测试环境进行配置和调试,并确保对服务器的访问进行适当的身份验证和安全措施。 ### 回答3: 在Nginx查看POST请求参数,可以通过以下步骤: 1. 首先,需要在Nginx的配置文件开启请求参数的记录。找到nginx.conf文件,一般位于/etc/nginx/或/usr/local/nginx/的conf目录下。在http {}段添加以下代码: ``` http { log_format postdata '$remote_addr - $remote_user [$time_local] "$request" $status $body_bytes_sent "$http_referer" "$http_user_agent" "$request_body"'; access_log /var/log/nginx/access.log postdata; ... } ``` 2. 配置完成后,重启Nginx服务以使配置生效。 3. 当有POST请求发生时,Nginx会将请求参数记录在上述配置文件指定的日志文件。 4. 查询POST请求参数,可以打开配置文件指定的日志文件,通常位于/var/log/nginx/access.log。该文件记录了所有请求的详细信息,包括请求方式(POST)、请求URL、请求状态码、请求体大小、来源页、用户代理以及请求参数等信息。 在日志文件POST请求参数通常以$request_body的形式记录在一行,通过分析该行,即可查看POST请求所提交的参数。 需要注意的是,这种方式适用于需要在Nginx层面查看POST请求参数的场景,如果想在应用程序获取POST请求参数,应该通过编程的方式来处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值