Docker No Route to Host解决办法
问题描述:
在服务器上拉了两个docker容器A和B, 容器A用来跑平时实验, 容器B搭了一个postgresql数据库。现想从容器A访问容器B的数据库内容, 在使用psycopg2连接postgresql时, 在主机地址和端口号都正确的条件下, 一直报Docker No Route to Host的错误. 并且, 在本地测试数据库的连接性时, 一直是可以连接的.
解决方案:
主要原因在服务器屏蔽从docker内部的访问, 修改服务器的防火墙设置即可.
(1) 在容器A内输入命令"ifconfig"查看容器A的ip地址, 若无该命令, 可通过"apt-get install net-tools"安装.
(2) 在服务器内修改配置文件"vi /etc/firewalld/zones/public.xml"添加容器A的ip地址, 具体内容如下:
<rule family="ipv4">
<source address="172.17.0.0/16"/> # 这个地址与容器A的ip地址对应
<accept/>
</rule>
注: 另一种修改该配置文件的方式, 在服务器内输入命令"firewall-cmd --permanent --zone=public --add-rich-rule='rule family=ipv4 source address=172.17.0.0/16 accept'"和"firewall-cmd --reload".
(3) 重启服务器防火墙"systemctl restart firewalld".
上一篇: Error from server: Get https://xx:10250/containerLogs dial tcp 10250: connect: no route to host
下一篇: nginx connect() failed (113: No route to host) while connecting to upstream
推荐阅读
-
docker host net mtu (by quqi99)
-
docker 互相访问出现 No route to host 博客分类: docker
-
docker 互相访问出现 No route to host 博客分类: docker
-
connect to host slavenode1 port 22: No route to host
-
ssh: connect to host 10.224.120.107 port 22: No route to host
-
ubuntu: ssh: connect to host ubuntu port 22: No route to host
-
解决telnet时no route to host的错误
-
Ubuntu 16.04 远程 ssh: connect to host x.x.x.x port xxx: No route to host
-
ssh: connect to host 192.168.1.20 port 22: No route to host解决方案
-
centos8: 执行 telnet ip port 报错 No route to host