文章目录
- 1. Docker容器之间通信的主要方式
- 1.1 通过容器ip访问
- 1.2. 通过宿主机的ip:port访问
- 1.3. 通过link建立连接(官方不推荐使用)
- 1.4. 通过 User-defined networks(推荐)
- 2. 参考资料
1. Docker容器之间通信的主要方式
1.1 通过容器ip访问
容器重启后,ip会发生变化。通过容器ip访问不是一个好的方案。
1.2. 通过宿主机的ip:port访问
通过宿主机的ip:port访问,只能依靠监听在暴露出的端口的进程来进行有限的通信。
容器之间通信不能用 localhost
、127.0.0.1
,只能用宿主机的 ip:port
通信,但是主机的ip地址会随着宿主机的重启而变化
以 MySQL 容器为例如下:
-
创建容器
docker run -it -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=root mysql:5.7
-
主机直接访问暴露的端口
如下图,暴露端口的方式很方便主机与容器之间的通信,跟连接主机本地一样
1.3. 通过link建立连接(官方不推荐使用)
运行容器时,指定参数link,使得源容器与被链接的容器可以进行相互通信,并且接受的容器可以获得源容器的一些数据,比如:环境变量。
# 源容器:mysql
docker run -itd --name mysql_test -e MYSQL_ROOT_PASSWORD=root mysql:5.7
#被链接容器 centos
docker run -itd --name centos_test --link test-mysql:mysql centos /bin/bash
#进入test-centos
docker exec -it centos_test /bin/bash
1.4. 通过 User-defined networks(推荐)
先给出结论:
-
配置
-p
选项让宿主机和容器之间通过暴露端口
来通信 -
配置
--network
选项让容器加入同一个网络,也配置--network-alias
选项让容器间相互连接
以centos
和mysql
容器之间通信为例,使用方法步骤如下:
-
创建网络
docker network来创建一个桥接网络,在docker run的时候将容器指定到新创建的桥接网络中,这样同一桥接网络中的容器就可以通过互相访问。
docker network create dockerbetweennetwork
-
启动mysql容器时,加入创建的网络
创建mysql容器加入到dockerbetweennetwork网络,也暴露了3306端口给主机使用
# 创建mysql容器 docker run -it -p 3306:3306 --name mysql_test \ --network dockerbetweennetwork --network-alias mysql_network \ -e MYSQL_ROOT_PASSWORD=root \ -d mysql:5.7
-
启动centos容器时,加入创建的网络
# 创建centos容器 docker run -it --name centos_test \--network dockerbetweennetwork --network-alias centos_network \ -d centos
-
验证结果
-
查看mysql容器的ip地址
# 查看mysql容器ip地址 docker inspect mysql_test
我的mysql_test的ip地址是
172.21.0.2(mysql)
-
进入centos容器中查看是否跟mysql容器在同一个网络
# 进入centos容器中 docker exec -it centos_test /bin/bash # ping 上面得到的mysql容器的地址 ping mysql_test
-
2. 参考资料
我的文章:《Docker 设置国内镜像源.md》
我的文章:《Docker 快速入门实用教程.md》
我的文章:《如何查看一个 Docker 镜像有哪些版本.md》
我的文章:《Docker安装启动MySQL、Redis、RabbitMQ、Elasticsearch、Nacos等等常见服务.md》
传送门:保姆式Spring5源码解析
欢迎与作者一起交流技术和工作生活
联系作者