map
和if
指令可以屏蔽F5心跳日志并记录指定IP访问日志。具体配置如下:,,“,http {, # 定义一个名为block_f5的变量,用于屏蔽F5心跳日志, map $remote_addr $block_f5 {, default 0;, 192.168.1.1 1; # 将F5负载均衡器的IP地址替换为实际的IP地址, },, access_log /var/log/nginx/access.log combined;,, server {, listen 80;,, location / {, # 如果请求来自F5负载均衡器,则不记录日志, if ($block_f5) {, return 204;, },, # 其他正常处理逻辑, }, },},
`,,这段配置将会屏蔽F5负载均衡器的心跳日志,并将访问日志记录到
/var/log/nginx/access.log`文件中。请根据实际情况修改F5负载均衡器的IP地址。 在Nginx中屏蔽F5心跳日志和指定IP访问日志,可以通过配置文件中的相关指令实现,以下是具体的配置示例:
Nginx 配置示例
server { listen 80; server_name example.com; location / { proxy_pass http://mmt; proxy_set_header Host $host; proxy_set_header XRealIP $remote_addr; proxy_set_header XForwardedFor $proxy_add_x_forwarded_for; proxy_redirect off; # 屏蔽F5心跳日志 if ($remote_addr != 192.168.0.2) { access_log /var/log/nginx/nginx_access_abres.log; } } # 指定IP访问日志 location /restricted { allow 192.168.0.3; # 允许的IP地址 deny all; # 拒绝其他所有IP地址 access_log /var/log/nginx/nginx_ip_access.log; } }
配置说明
配置项 | 作用 |
listen 80 | 监听80端口 |
server_name example.com | 设置服务器名称为example.com |
location / | 匹配根路径下的所有请求 |
proxy_pass http://mmt | 将请求转发到后端服务器mmt |
proxy_set_header Host $host | 设置代理头部信息Host为当前主机名 |
proxy_set_header XRealIP $remote_addr | 设置代理头部信息XRealIP为客户端真实IP |
proxy_set_header XForwardedFor $proxy_add_x_forwarded_for | 设置代理头部信息XForwardedFor为客户端IP链表 |
proxy_redirect off | 禁止重定向 |
if ($remote_addr != 192.168.0.2) | 如果客户端IP不是192.168.0.2,执行以下操作 |
access_log /var/log/nginx/nginx_access_abres.log | 记录访问日志到指定文件 |
location /restricted | 匹配路径为/restricted的请求 |
allow 192.168.0.3 | 仅允许IP为192.168.0.3的访问 |
deny all | 拒绝其他所有IP的访问 |
access_log /var/log/nginx/nginx_ip_access.log | 记录指定IP的访问日志到指定文件 |
常见问题解答 (FAQs)
Q1: 为什么使用if语句来屏蔽F5心跳日志时仍然会记录日志?
A1: 推测是因为日志记录在deny前执行,当执行到deny返回403 Forbidden时,已经记录了日志,需要调整配置顺序或使用其他方法来实现。
Q2: 如何确保只有特定IP能够访问某个路径?
A2: 可以使用Nginx的allow和deny指令来限制访问,在上述配置中,我们允许IP为192.168.0.3的客户端访问/restricted路径,并拒绝其他所有IP的访问,我们还为该路径设置了单独的访问日志。
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。