服务器之家:专注于服务器技术及软件下载分享
分类导航

云服务器|WEB服务器|FTP服务器|邮件服务器|虚拟主机|服务器安全|DNS服务器|服务器知识|Nginx|IIS|Tomcat|

服务器之家 - 服务器技术 - 服务器知识 - Docker中iptables规则在iptables重启后丢失的完整过程

Docker中iptables规则在iptables重启后丢失的完整过程

2021-04-28 20:11Captain_Li 服务器知识

这篇文章主要给大家介绍了关于Docker中iptables规则在iptables重启后丢失的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Docker具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

前因后果

1、在跳板机上使用ansible命令测试机器b时,报错如下,于是就怀疑是网络防火墙的问题

?
1
2
3
4
5
10.10.0.86 | failed >> {
 "failed": true,
 "msg": "/bin/sh: /usr/bin/python: no such file or directory\r\nopenssh_7.6p1 ubuntu-4ubuntu0.3, openssl 1.0.2n 7 dec 2017\r\ndebug1: reading configuration data /etc/ssh/ssh_config\r\ndebug1: /etc/ssh/ssh_config line 19: applying options for *\r\ndebug1: auto-mux: trying existing master\r\ndebug1: mux_client_request_session: master session id: 2\r\nshared connection to 10.10.0.86 closed.\r\n",
 "parsed": false
}

2、登录到机器b上,这是一台线上的机器,里面运行docker容器,然后我看平时的经验一般是网络防火墙有问题就直接

?
1
2
3
systemctl stop iptables
systemctl stop firewalld

3、然后我想着这应该不会影响容器吧,就看容器的日志,没想到10几个全部报错,都是连接不上,有点慌...,重启容器,完全是起不来的,报错如下

?
1
2
3
docker: error response from daemon: driver failed programming external connectivity on endpoint happy_ptolemy (9cedc114be35eb86cd6f7f7bb4f11f93b5f8d2c0745afc72664cef8e96aad439): iptables failed: iptables --wait -t filter -a docker ! -i docker0 -o docker0 -p tcp -d 10.10.0.86 --dport 3000 -j accept: iptables: no chain/target/match by that name.
 
(exit status 1).

4、解决办法,重启docker

?
1
systemctl restart docker

知识点

1、netfilter与iptables的关系

netfilter是在linux内核中的一个防火墙框架,用于管理网络数据包,不仅具有网络地址转换(nat)的功能,也具有数据包内容修改,以及数据包过滤等防火墙功能。利用在用户空间的应用软件iptables等来控制netfilter(iptables只是应用软件,工具)。

Docker中iptables规则在iptables重启后丢失的完整过程

2、iptables与firewalld的关系

firewalld和iptables一样都是应用软件,是工具,但是他的底层还是先通过iptables。

Docker中iptables规则在iptables重启后丢失的完整过程

3、docker与firewalld、iptables的关系

1)docker安装完成后,会自动接管iptables或者firewalld,在docker run的时候,会自动往iptables里加入规则;所以当iptables重启后会丢失,只有再重启docker就好了的原因。

2)当使用systemd 的时候, firewalld 会在 docker 之前启动,但是如果你在 docker 启动之后再启动 或者重启 firewalld ,就需要重启 docker 进程了。

总结

1、对生产环境的敬畏

2、对知识点的理解不透彻,不知道什么场景能用,什么场景不能用

3、后面还需要把防火墙的规则再深入了解

到此这篇关于docker中iptables规则在iptables重启后丢失的文章就介绍到这了,更多相关docker中iptables规则重启后丢失内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/lemon-le/p/12976999.html

延伸 · 阅读

精彩推荐