Docker第一讲 Docker容器间/容器与宿主机ping不通解决

容器之间通信的主要方式

  • 通过容器ip访问

容器重启后,ip会发生变化。通过容器ip访问不是一个好的方案。

  • 通过宿主机的ip:port访问

通过宿主机的ip:port访问,只能依靠监听在暴露出的端口的进程来进行有限的通信。

  • 通过link建立连接(官方不推荐使用)

运行容器时,指定参数link,使得源容器与被链接的容器可以进行相互通信,并且接受的容器可以获得源容器的一些数据,比如:环境变量。

# 源容器
docker run -itd --name container -e MYSQL_ROOT_PASSWORD=root mysql:5.7
#被链接容器 
docker run -itd --name container --link test-mysql:mysql  centos /bin/bash
#进入容器
docker exec -it container /bin/bash
  • 通过 User-defined networks(推荐)

docker network来创建一个桥接网络,在docker run的时候将容器指定到新创建的桥接网络中,这样同一桥接网络中的容器就可以通过互相访问。

docker run -it --network network --network-alias mysql  -e MYSQL_ROOT_PASSWORD=123 mysql:5.7

启动被链接的容器

 docker run -it --network test-network --network-alias centos  centos /bin/bash

Docker宿主机与容器通信

首先是关于防火墙的问题,可以查看本地自己的防火墙配置,可以关闭防火墙继续下部操作

对于宿主机与容器无法通信的,因为默认的容器网络是采用bridge的桥接形式,会在容器内部开辟自己的网段,所以,你接下来需要用到的几个命令如下:

ifconfig
查看下你本地的docker网络配置
docker network inspect [你容器挂载的network]
查看你的容器网络分段ip地址
route -n 
查看你的本地容器地址

查看下你本地network网络是不是与我的一致,如果你想修改你本地network网段,可以做下面操作

"default-address-pools" : [
    {
      "base" : "192.168.1.0/8",
      "size" : 24
    }
  ]

指定你的网段192.168.1.0/8,size:24,本地就会设置192.0.0.1的docker网段,记住修改后需要重新启动docker

systemctl restart docker

你可以将之前的network删除,本地重新创建一个network再次查看你创建的network的网段地址,就会发生变化,关于Network网络配置你可以参考这篇博客: Docker第四讲 Docker network网络模式讲解

如果你有遇到其他的什么问题,欢迎留言

如果本文档无法帮助到你,可以参考这篇博客:

docker容器ping不通宿主机与外网问题排查及解决

### 问题排查方法 当宿主机无法 `ping` 通 Docker 容器时,通常是由于网络配置或系统限制导致的。以下是一些常见的排查步骤和解方案: #### 1. 检查容器网络模式 Docker 支持多种网络模式,例如默认的桥接模式(`bridge`)、主机模式(`host`)等。在 macOS 和 Windows 上,`--net=host` 可用,因此需要依赖自定义桥接网络来实现通信 [^4]。 - 查看当前容器使用的网络: ```bash docker inspect <container_id> | grep NetworkMode ``` - 如果使用的是默认桥接网络(`bridge`),可以尝试创建自定义桥接网络并重新启动容器: ```bash docker network create my_bridge_network docker run --network my_bridge_network -d --name redis_container redis ``` #### 2. 获取容器 IP 地址 在宿主机上查看容器分配的 IP 地址: ```bash docker inspect <container_id> | grep IPAddress ``` 然后尝试从宿主机 `ping` 该 IP 地址: ```bash ping <container_ip> ``` 如果仍然无法 `ping` 通,则可能是网络驱动或系统环境的问题 [^2]。 #### 3. 使用 Host 网络或端口映射 在 macOS 和 Windows 上,Docker 是通过虚拟机(如 Hyper-V 或 WSL2)运行的,这意味着容器直接暴露给宿主机网络。可以通过将容器端口映射到宿主机的方式来访问服务 [^4]。 - 启动容器时映射端口: ```bash docker run -d -p 6379:6379 --name redis_container redis ``` - 在宿主机上通过 `localhost:6379` 访问 Redis 服务。 #### 4. 配置 DNS 和防火墙规则 有时,DNS 解析失败也会导致连接异常。可以尝试手动指定 DNS 服务器或检查本地 `/etc/hosts` 文件是否正确配置 [^1]。 此外,在 Windows 上还需要检查防火墙设置,确保允许 Docker 的网络流量通过: - 打开“控制面板” > “系统和安全” > “Windows Defender 防火墙” - 添加例外规则,允许 Docker 相关程序(如 `docker.exe`、`com.docker.backend`)通过防火墙 #### 5. 使用 Docker Desktop 的网络诊断工具 Docker Desktop 提供了内置的网络诊断功能,可以帮助识别并修复常见网络问题。可以在 Docker Desktop 的菜单中选择 **Troubleshoot** > **Diagnose & Feedback** 来运行诊断工具 [^3]。 #### 6. 针对 Mac 用户的额外建议 对于 macOS 用户,由于 Docker在原生 Linux 环境下运行,而是基于虚拟化技术(如 Moby VM),因此传统的 `docker0` 网桥会出现在宿主机的网络接口列表中 。 - 可以通过安装第三方工具如 `docker-connector` 来建立更稳定的网络连接。 - 使用如下命令安装 `docker-connector`(需先安装 Homebrew): ```bash brew install docker-connector ``` - 安装完成后重启 Docker 并测试网络连通性。 #### 7. 使用容器通信 如果多个容器部署在同一自定义网络中,它们可以通过服务名称互相访问。例如,一个 Spring Boot 应用可以使用 Redis 容器的服务名称作为主机名进行连接 [^5]。 --- ### 示例代码:Spring Boot 连接 Redis 容器 ```java @Configuration public class RedisConfig { @Bean public RedisConnectionFactory redisConnectionFactory() { return new LettuceConnectionFactory(new RedisStandaloneConfiguration("redis_container", 6379)); } @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(factory); template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(new GenericJackson2JsonRedisSerializer()); return template; } } ``` --- ###
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员路同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值