环境准备
| 服务器系统 | Centos7.3 |
|---|---|
| 内存 | 1G |
| CPU | 2核 |
| IP地址 | 10.0.0.44 |
docker pull busybox
docker run --name mysql -h mysql-server -it busybox /bin/sh
再开一个窗口
docker run -h wordpress -it --link mysql:db-server busybox /bin/sh


ping db-server

exit
docker rm mysql
docker run --name mysql111 -h mysql-server -it busybox /bin/sh

再打开一个窗口

再第二个窗口上操作
docker run --name mysql -h mysql-server -it busybox /bin/sh




然后把第一个窗口关掉
在第二个窗口操作
docker run -h node1 --name node1 -d busybox ping 127.0.0.1
在第一个窗口操作
docker run -h node2 --name node2 -d --link node1:mysql-server busybox ping 127.0.0.1


在第一个窗口操作
docker exec -it node2 /bin/sh
ping node1
ping mysql-server

在第二个窗口操作
docker run -h node3 --name node3 -d busybox ping 127.0.0.1
在第一个窗口操作,让它一直去ping,不要终止
ping mysql-server

在第二个窗口操作
docker stop node1
docker stop node3
docker start node3
docker start node1
docker exec -it node1 /bin/sh
ifconfig

在回到第一个窗口操作,终止一下,再开始ping
ping mysql-server

所以,再有些容器连接是比较密切的话,建议在run的时候加个–link,特别是跟一些数据库相关的,在连接数据库的时候都加上–link,加上以后再连接数据库的时候DB那块儿DB host那块可以写它的主机名了,或者写它link的一个名字,通过名字去做连接通信会比IP要好很多
本文详细介绍了使用Docker进行容器间通信的方法,包括如何利用--link参数增强容器间的链接稳定性,尤其是在涉及数据库连接的场景中,展示了一系列Docker命令操作实例。
451

被折叠的 条评论
为什么被折叠?



