docker 学习笔记-7


桥接网络 Bridge Network

docker的桥接网络使用虚拟网桥,bridge网络用于同一主机上的docker容器相互通信,连接到同一个网桥的docker容器可以相互通信,当我们启动docke时,会自动创建一个默认bridge网络,除非我们进行另外的配置,新创建的容器都会自动连接到这个网络,我们也可以自定义自己的bridge网络,docker文档建议使用自定义bridge网络,默认的bridge网络具有一定的缺陷

https://docs.docker.com/engine/reference/commandline/swarm/

实例演示:容器之间通过自定义Overlay 跨主机通讯

为了演示跨主机,我这里克隆一个虚拟机,现两个虚拟机的信息如下

虚拟机IP安装
ubuntu 192.168.147.128 redis
ubuntu_copy1 192.168.147.130 mysql
  1. 在128上初始化集群
docker swarm init

2. 在128上查看当前节点
docker node ls

3. 在128上创建overlay network
docker network create --driver=overlay --attachable test-overla

4. 在128上实例redis容器,并加入overlay 网络
docker run -tid --name redis_overlay --network test-overlay redis:5.0

5. 在130中,加入集群
docker swarm join --token SWMTKN-1-32pd1ytuwho780hrehx8687y4s54g0fvhf4sh8tx8ea1qp9a6g-9foali4ph3tm0xn5vmu0emomd 192.168.147.128:2377

如果不记得token了,可以在128上执行命令
docker swarm join-token worker 即可显示加入集群的命令

  1. 在130上实例mysql容器,并加入overlay网络
docker run -tid --name mysql_overlay --network test-overlay -e MYSQL_ROOT_PASSWORD=root  mysql:5.6

7. 从128中redis容器中测试连接130中的mysql容器
docker exec -it redis_overlay /bin/telnet mysql_overlay 3306

到这里,已经说明通过加入overlay网络,在两个主机的两个容器之间可以实现通信了。

如果容器内telnet命令不存在,在容器内先更新apt,然后安装telnet即可
apt update
apt install telnet

相关