版权声明: https://blog.csdn.net/Scirhh/article/details/85619501
启动docker映射到宿主机时出现如下错误时:
/usr/bin/docker-current: Error response from daemon: driver failed programming external connectivity on endpoint sc_mysql (1bc03030afe9f722ae1e6b46166172a70cf87bcc3f02f0acdac0be2a7f0f0036): (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 3306 -j DNAT --to-destination 172.17.0.2:3306 ! -i docker0: iptables: No chain/target/match by that name.
这是由于来自守护进程的错误响应,而致使外部连接失败。解决的办法就是将其docker进程
kill掉,然后再 清空掉iptables下nat表下的所有链(规则)
。最后,将 docker的网桥删除,并重启docker服务
[root@7con ] pkill docker #终止进程
[root@7con ] iptables -t nat -F #清空nat表的所有链
[root@7con ] ifconfig docker0 down #停止docker默认网桥
[root@7con ] yum install bridge-utils -y # 部分机器是无法使用brctl,所以需要提前安装
[root@7con ] brctl delbr docker0 #删除网桥
[root@7con ] systemctl restart docker #重启docker
docker镜像成功映射后,会在 iptables
上添加所属的链,如图:
感谢阅读,本文旨在提供参考,如有错误,欢迎大家指正。帮助编者不断的改进!