這篇文章主要介紹了docker多容器連接(以tomcat+docker為例),docker提供了多個容器直接訪問的方法,可以使多個容器直接通過網絡端口進行訪問
Docker提供了多個容器直接訪問的方法,最簡單的方式是直接使用端口映射-p參數指定映射的端口或者-P映射所有端口,多個容器直接通過網絡端口進行訪問。
但網絡端口映射方式并不是Docker中連接多個容器的唯一方式,更安全的方法是可以使用Docker的連接系統(–link)連接多個容器,當容器連接到一起時,接受者容器就可以看到源容器的信息。
以Tomcat + Mysql為例,建立容器之間的連接
在容器直接建立連接要使用–link選項
–link
這里我們通過建立一個 Tomcat + Mysql 的服務,示例一下如何在兩個或者多個容器之間建立連接。
要建立容器連接的話,就要依賴容器的名字了,使用–name指定源容器的名字為mysql
docker?run?--name?mysql?-d?gsoft/mysql:5.6
接下來創建tomcat容器,并且連接到mysql容器上去
?代碼如下:
docker?run?--name?tomcat?-d?-p?80:8080?--link?mysql:mysql?gsoft/tomcat:7.0
這里通過–link選項指定了要連接的容器是mysql。
容器互通信息
建立兩個容器之間的連接之后,在接收容器(Recipient)中必然會需要訪問源容器(Source)的資源,我們在為容器建立連接時,源容器在創建時并沒有使用-p/-P指定要暴露出來的端口,因此如何訪問源容器的信息呢?
為了可以讓接收容器能夠訪問源容器的信息,Docker提供了兩種方式:
-
環境docker
-
/etc/hosts文件
環境變量
Docker在連接容器的時候,會根據–link提供的參數自動的在接收者容器中創建一些環境變量,包括源容器的Dockerdocker中使用ENV命令設置的環境變量和源容器啟動時(docker run),使用-e或者–env, –env-file參數指定的環境變量。
主要包含以下環境變量,這里假設alias=mysql。
<alias>_PORT <alias>_PORT_<port>_<protocol><alias>_PORT_<port>_<protocol>_ADDR <alias>_PORT_<port>_<protocol>_PORT <alias>_PORT_<port>_<protocol>_PROTO <alias>_NAME</alias></protocol></port></alias></protocol></port></alias></protocol></port></alias></protocol></port></alias></alias>
例如:
#docker?run?-i?-t?--rm?--link?mysql:mysql?ubuntu:14.04?env PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin HOSTNAME=9c74aa611463 TERM=xterm MYSQL_PORT=tcp://172.17.0.3:3306 MYSQL_PORT_3306_TCP=tcp://172.17.0.3:3306 MYSQL_PORT_3306_TCP_ADDR=172.17.0.3 MYSQL_PORT_3306_TCP_PORT=3306 MYSQL_PORT_3306_TCP_PROTO=tcp MYSQL_NAME=/desperate_ritchie/mysql HOME=/root
上述例子中,指定了容器的別名為msyql,因此所有環境變量都是以MYSQL_開頭。
注意的是,如果源容器重啟,接收容器中的環境變量信息并不會自動docker,因此,如果要使用源容器的IP地址,請使用/etc/hosts中配置的主機信息。
/etc/hosts文件
除了環境變量之外,Docker也在接收容器的/etc/hosts文件中更新了hosts信息。
#?docker?run?-i?-t?--rm?--link?mysql:mysql?ubuntu:14.04?/bin/bash #?cat?/etc/hosts 127.0.0.1??localhost ::1??localhost?ip6-localhost?ip6-loopback fe00::0??ip6-localnet ff00::0??ip6-mcastprefix ff02::1??ip6-allnodes ff02::2??ip6-allrouters 172.17.0.3??mysql?115346bdb403 172.17.0.5??09bdf7805133
從上可以看出,在接收容器的hosts文件中增加了兩條額外的信息,本機IP和別名以及源容器的IP和別名(mysql)。
與環境變量不同的是,如果源容器重啟了,接收容器中/etc/hosts中的信息會自動更新。