Docker多容器連接(以Tomcat+Mysql為例)
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è)容器之間建立連接。
要建立容器連接的話,就要依賴容器的名字了,使用--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提供了兩種方式:
- 環(huán)境變量
- /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)更新。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用docker部署django技術(shù)棧項(xiàng)目的方法步驟
這篇文章主要介紹了使用docker部署django技術(shù)棧項(xiàng)目的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09Docker中Dockerfile之容器中運(yùn)行MyEclipse搭建的JavaWeb項(xiàng)目
本篇文章主要介紹了Docker中Dockerfile之容器中運(yùn)行MyEclipse搭建的JavaWeb項(xiàng)目,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02docker啟動(dòng)mysql及-e MYSQL_ROOT_PASSWORD=my-secret-pw問(wèn)題解決
本文主要介紹了docker啟動(dòng)mysql及-e MYSQL_ROOT_PASSWORD=my-secret-pw問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07單機(jī)docker-compose部署minio過(guò)程
簡(jiǎn)述通過(guò)Docker-Compose在單機(jī)上掛載多硬盤實(shí)現(xiàn)MinIO多副本部署的方法,包括配置docker-compose.yaml和nginx.conf等關(guān)鍵步驟,適合服務(wù)器資源有限的場(chǎng)景2024-10-10解決docker網(wǎng)絡(luò)錯(cuò)誤(network bridge not found)
這篇文章主要介紹了解決docker網(wǎng)絡(luò)錯(cuò)誤(network bridge not found)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08為運(yùn)行中的docker容器設(shè)置時(shí)區(qū)
本文主要介紹了為運(yùn)行中的docker容器設(shè)置時(shí)區(qū),主要介紹了2種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-05-05Docker consul的容器服務(wù)更新與發(fā)現(xiàn)的問(wèn)題小結(jié)
這篇文章主要介紹了Docker consul的容器服務(wù)更新與發(fā)現(xiàn),講解了服務(wù)注冊(cè)與發(fā)現(xiàn)的基本概念講解,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-08-08vscode利用ssh配置docker容器并開(kāi)啟遠(yuǎn)程編程模式的詳細(xì)步驟
這篇文章主要介紹了vscode利用ssh配置docker容器內(nèi)開(kāi)啟遠(yuǎn)程編程模式,本文給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03Docker Compose 搭建簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序(步驟詳解)
在這個(gè)頁(yè)面上,你可以建立一個(gè)簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序,運(yùn)行在Docker Compose上,這篇文章主要介紹了Docker Compose 搭建簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序,需要的朋友可以參考下2022-07-07