# 场景描述
在 centos7
运行 docker
容器应用时,需要连接宿主机的 mysql
的 3306
端口,发现连接不上,docker
容器无法访问宿主机的 mysql
数据库。但是,在容器内访问外部网络是可以 ping
通的。
# 原因分析
在 centos7
上部署 docker
容器,其网络模式采用的是 bridge
模式。
启动 docker
时,docker
进程会创建一个名为 docker0
的虚拟网桥,用于宿主机与容器之间的通信。当启动一个 docker
容器时,docker
容器将会附加到虚拟网桥上,容器内的报文通过 docker0
向外转发。
如果 docker
容器访问宿主机,那么 docker0
网桥将报文直接转发到本机,报文的源地址是 docker0
网段的地址。而如果 docker
容器访问宿主机以外的机器,docker
的 SNAT
网桥会将报文的源地址转换为宿主机的地址,通过宿主机的网卡向外发送。
因此,当 docker
容器访问宿主机时,如果宿主机服务端口会被防火墙拦截