Docker部署Nginx,无法获取客户端真实ip地址

在部署docker版本nginx进行请求转发,意外发现nginx打印日志中的客户端ip并非为客户端的真实ip(221.237.xxx.xxx),而是docker虚拟网卡的ip(172.17.0.1)
开始猜测是nginx配置问题,对比其他环境,发现配置相同,但其他环境未出现此情况

image.png

通过查询资料,推测是docker网桥和linux防火墙存在冲突,但是系统的防火墙已经关闭,不知道为啥会有影响。尝试把docker网桥加入到防火墙的internal区域,测试一下效果。
1.通过ifconfig -a 找到docker网桥的名称

image.png

2.把网桥加入到防火墙的internal(内部)区域
firewalld-cmd –permanent –zone=internal –change-interface=docker0(网桥名称)
3.重启firewalld,我的防火墙已经关闭了,启动后加上配置又把它关掉(感觉没用)
4.再次查询日志发现没有效果。。。
再上网查询docker和firewalld的冲突问题后,发现并不是docker和防火墙有冲突,而是docker与防火墙管理工具firewalld有冲突(CentOs 6 中使用iptables来管理防火墙,到了CentOs 7 默认使用firewalld来管理防火墙)。firewalld启动或者重启会将iptables的规则清空,其中就包含docker相关的规则
继续推测,启动firewalld时,虽然把docker网桥加入了internal区域,但同时又将iptables的规则清空掉了,所以我们添加的配置对于docker来说仍然没有起作用,这时就需要重启docker将相关规则进行重建。
systemctl restart docker
再次查看日志,成功获取到客户端真实ip

image.png
以上仅为个人的一些推测,若有错误或者其他见解,还请大佬们指正

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值