docker导致远程主机无法访问,docker网段冲突导致主机网络异常无法访问

背景:

        公司分配的虚拟机是172网段的,在上面部署了docker、docker-compose、mysql、redis,程序用docker-compose管理,也平稳运行了一个多周,某天用FinalShell连主机重启docker容器,忽然断开连接,然后虚拟机就无法远程连接了,公司平台组通过后台连接虚拟机正常,网络正常。

原因:

        docker默认的网段是172的,和虚拟机的网络冲突,导致的虚拟机无法访问。

解决办法:

        在/etc/docker目录下的daemon.json文件中增加ip段,如果没有该文件,新建一个即可,限制docker网络的ip,注意配置的ip段不要和现有网络环境的ip段相同,然后在重启docker就可以了。

{
  "bip":"192.168.100.1/16"
}

如果系统中还安装了docker-compose,容器是通过docker-compose的yml文件启动的,要在yml文件中增加docker-compose的网络配置:

networks:
  default:
    name: milvus
    ipam: 
      driver: default
      config:
        - subnet: 10.103.0.0/16

注意:如果系统已经使用docker-compose启动了容器,要先停止该容器,并删除该容器,更改过docker-compose的yml配置后再从新运行容器,不然,配置不起作用。

本人就是修改完docker的网络配置,和docker-compose的网络配置,一启动docker,还是连不上虚拟机,经排查发下,之前docker-compose运行的镜像还在docker中, 所以一启动docker,就会运行该容器,该容器的网络还是172的,所以还会有问题,让平台组先从后台先将这个网络删除,然后就可以登录虚拟机了, 再用docker rm 删除该容器,再启动用docker-compose up -d 重新运行生成容器即可。

你可能感兴趣的:(随笔,docker,网络,linux)