docker 容器之间通信
任务
一个容器内启动nginx向外提供服务 另一个容器访问nginx(两个容器通信)
docker在与宿主机通信的时候会建立一个名为docker0的虚拟网卡,然后为每一个容器分配一个私有网段内的,借助此ip可以进行通信。但是,每次容器重新启动的时候,ip会重新分配,可能会发生变动,也就是说我们无法提前获取ip。所以能不能通过container_name进行通信呢?答案是可以。
解决
link方式#
docker run 的时候使用 --link选项,先正常启动第一个容器,然后启动第二个容器的时候使用 --link选项与第一个容器建立连接
但是,只能单向通信,如果想从容器1访问容器2依然需要ip,或者在/etc/hosts文件里配置一下ip和container_name container_id的映射关系。可是如果ip发生了变化,就需要修改一下。因此抛弃这个方案。
自定义网络#
通过 docker network create 创建一个新的网络
配置红线部分的参数(网络模式、默认网关、子网)
docker network create --driver bridge --subnet 10.0.0.0/8 --gateway 10.0.0.1 my_net_test1
查看一下,发现已经创建完成了
docker network ls
接下来,在启动容器的时候指定其使用该网络即可
docker run -td --net my_net_test1 --ip 10.0.0.111 --name test0 ubuntu:20.04
此时已经可以使用容器名称进行通信,ip发生变化不受影响。
从另一个容器ping test0
用它ping另一个容器
参考
容器互联之自定义网络
作者: correct
出处:https://www.cnblogs.com/correct/p/16548375.html
本站使用「CC BY 4.0」创作共享协议,转载请在文章明显位置注明作者及出处。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」