我们在实际项目中可能会有种需求,假如我们有个后台项目,它要访问数据库,比如MySQL,它想要访问数据库,就需要数据库的ip和端口。如果有两个容器,一个容器启动的是数据库的MySQL服务,另一个容器启动的是后台服务,后台服务需要访问数据库。在这前我们必须要知道数据库的IP地址是什么。也就是说我们要手工的创建一个数据库MySQL的容器,启动之后再讲数据库容器的IP地址记录下来,然后在启动后台服务的时候,将数据库的IP地址配置在代码里面作为数据库的参数。
这种方式有一个问题,在我们写代码的时候有可能还不知道数据库的IP地址是什么。但是我们可以先给数据库容器起个名字,可以通过这个名字去访问这个数据库容器,不需要知道IP地址了。名字是不会变的。这时我们可以通过Docker的link机制,可以在创建第二个容器的时候,把它link到第一个容器上面。这样我在访问第一个容器的时候通过name就可以访问了。
现在我通过下面的命令创建容器flask-hello-docker1:
docker run --name flask-hello-docker1 -d -p 20000:20000 flask-hello-docker
然后,通过下面的命令创建flask-hello-docker2,并且将它link到flask-hello-docker1上面:
docker run --name flask-hello-docker2 --link flask-hello-docker1 -d -p 30000:30000 flask-hello-docker
创建完flask-hello-docker2容器之后,进入到这个容器里面。
docker exec -it flask-hello-docker2 /bin/sh
docker容器安装ping
apt-get update && apt-get install -y iputils-ping
在container里面执行ip a
apt-get update && apt-get install -y iproute2
然后,可以通过下面的命令,在flask-hello-docker2容器里面直接通过name,ping通flask-hello-docker1。
ping flask-hello-docker1
反过来,如果进入到容器flask-hello-docker1里面,通过ping flask-hello-docker2,通过名字ping是不行的。通过--link创建的连接具有方向性。
这个--link在实际情况下我们用的并不多。还有更方便的方式。
然后,我们将flask-hello-docker2停掉,然后删除掉,再重新运行flask-hello-docker2。
docker run --name flask-hello-docker2 -d -p 30000:30000 flask-hello-docker
这次运行flask-hello-docker2没有用--link,回到最原始的状态。
接下来我们来看另外的一个内容,我们来看看docker network。
我们在创建容器的时候,默认会连bridge这个network,但实际上我们在创建容器的时候可以指定连接的network。可以指定使用host或none这个network。甚至我们可以自己建立一个bridge,然后我们将新建的容器连到这个bridge上面。
新建一个network其实很简单。
docker network create -d bridge my-bridge
-d表示:-driver。
然后,通过下面的命令可以查看linux上的bridge。
brctl show
可以看到多了一个br-708dac0d94f1的bridge,这个就是我们新建的my-bridge。
然后,我们可以通过--network指定我们新建容器连接的network是哪个。
docker run --name flask-hello-docker3 --network my-bridge -d -p 40000:40000 flask-hello-docker
现在我们可以看到my-bridge这个network上已经连接上container了。没连容器之前interfaces是空的。
我们也可以用下面的命令,查看my-bridge这个network连接的container信息。
docker network inspect 708dac0d94f1
现在,一共有3个正在运行的container。
flask-hello-docker1和flask-hello-docker2连接的都是bridge这个network,flask-hello-docker3这个容器连接的是my-bridge这个network。其实,对于flask-hello-docker1和flask-hello-docker2来讲,我们也有办法将它们连接到my-bridge这个network上面。
现在,将flask-hello-docker2连接到my-bridge这个network上面。
docker network connect my-bridge flask-hello-docker2
然后,可以看到flask-hello-docker2已经连到了my-bridge这个network上面。其实,现在flask-hello-docker2即连到bridge上面,也连到了my-bridge上面。
然后,我们进入到flask-hello-docker3这个容器的shell里面。
docker exec -it flask-hello-docker3 /bin/sh
接下来我们来看一个比较神奇的事情,在容器flask-hello-docker3里面直接名称ping flask-hello-docker2。
ping flask-hello-docker2
根据之前讲的内容,如果在容器里面想通过名称直接ping另外一个容器的话,要通过--link参数指定才行,但是如果两个容器都连接到了自定义的network而不是默认的bridge这个network上面,是默认配置好相互之间的link的。
现在容器flask-hello-docker2和容器flask-hello-docker3都连接到了自己创建的my-bridge上面,所以它们两个容器可以相互通过名字ping通。