明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

Mysql+Tomcat創(chuàng)建Docker多容器連接的方法

[摘要]這篇文章主要介紹了Docker多容器連接(以Tomcat+Mysql為例),Docker提供了多個(gè)容器直接訪問(wèn)的方法,可以使多個(gè)容器直接通過(guò)網(wǎng)絡(luò)端口進(jìn)行訪問(wèn)Docker提供了多個(gè)容器直接訪問(wèn)的方法,最簡(jiǎn)單的方式是直接使用端口映射-p參數(shù)指定映射的端口或者-P映射所有端口,多個(gè)容器直接通過(guò)網(wǎng)絡(luò)端口進(jìn)...
這篇文章主要介紹了Docker多容器連接(以Tomcat+Mysql為例),Docker提供了多個(gè)容器直接訪問(wèn)的方法,可以使多個(gè)容器直接通過(guò)網(wǎng)絡(luò)端口進(jìn)行訪問(wèn)

Docker提供了多個(gè)容器直接訪問(wèn)的方法,最簡(jiǎn)單的方式是直接使用端口映射-p參數(shù)指定映射的端口或者-P映射所有端口,多個(gè)容器直接通過(guò)網(wǎng)絡(luò)端口進(jìn)行訪問(wèn)。

但網(wǎng)絡(luò)端口映射方式并不是Docker中連接多個(gè)容器的唯一方式,更安全的方法是可以使用Docker的連接系統(tǒng)(--link)連接多個(gè)容器,當(dāng)容器連接到一起時(shí),接受者容器就可以看到源容器的信息。

以Tomcat + Mysql為例,建立容器之間的連接

在容器直接建立連接要使用--link選項(xiàng)

--link <name or id>:alias

這里我們通過(guò)建立一個(gè) Tomcat + Mysql 的服務(wù),示例一下如何在兩個(gè)或者多個(gè)容器之間建立連接。

要建立容器連接的話,就要依賴(lài)容器的名字了,使用--name指定源容器的名字為mysql

docker run --name mysql -d gsoft/mysql:5.6

接下來(lái)創(chuàng)建tomcat容器,并且連接到mysql容器上去

代碼如下:

docker run --name tomcat -d -p 80:8080 --link mysql:mysql gsoft/tomcat:7.0

這里通過(guò)--link選項(xiàng)指定了要連接的容器是mysql。

容器互通信息

建立兩個(gè)容器之間的連接之后,在接收容器(Recipient)中必然會(huì)需要訪問(wèn)源容器(Source)的資源,我們?cè)跒槿萜鹘⑦B接時(shí),源容器在創(chuàng)建時(shí)并沒(méi)有使用-p/-P指定要暴露出來(lái)的端口,因此如何訪問(wèn)源容器的信息呢?

為了可以讓接收容器能夠訪問(wèn)源容器的信息,Docker提供了兩種方式:

  1. 環(huán)境變量

  2. /etc/hosts文件

環(huán)境變量

Docker在連接容器的時(shí)候,會(huì)根據(jù)--link提供的參數(shù)自動(dòng)的在接收者容器中創(chuàng)建一些環(huán)境變量,包括源容器的Dockerfile中使用ENV命令設(shè)置的環(huán)境變量和源容器啟動(dòng)時(shí)(docker run),使用-e或者--env, --env-file參數(shù)指定的環(huán)境變量。

主要包含以下環(huán)境變量,這里假設(shè)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

例如:

#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,因此所有環(huán)境變量都是以MYSQL_開(kāi)頭。

注意的是,如果源容器重啟,接收容器中的環(huán)境變量信息并不會(huì)自動(dòng)更新,因此,如果要使用源容器的IP地址,請(qǐng)使用/etc/hosts中配置的主機(jī)信息。

/etc/hosts文件

除了環(huán)境變量之外,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文件中增加了兩條額外的信息,本機(jī)IP和別名以及源容器的IP和別名(mysql)。

與環(huán)境變量不同的是,如果源容器重啟了,接收容器中/etc/hosts中的信息會(huì)自動(dòng)更新。

以上就是Mysql+Tomcat建立Docker多容器連接的方法的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門(mén)到精通的SQL知識(shí)。