阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

以Tomcat+MySQL为例,实现Docker多容器连接

168次阅读
没有评论

共计 2491 个字符,预计需要花费 7 分钟才能阅读完成。

Docker 提供了多个容器直接访问的方法,最简单的方式是直接使用端口映射 -p 参数指定映射的端口或者 -P 映射所有端口,多个容器直接通过网络端口进行访问。

但网络端口映射方式并不是 Docker 中连接多个容器的唯一方式,更安全的方法是可以使用 Docker 的连接系统 (--link) 连接多个容器,当容器连接到一起时,接受者容器就可以看到源容器的信息。

以 Tomcat + MySQL 为例,建立容器之间的连接 

在容器直接建立连接要使用 --link 选项

--link <name or id>:alias

这里我们通过建立一个 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 提供了两种方式:

  • 环境变量
  • /etc/hosts 文件

环境变量

Docker 在连接容器的时候,会根据 --link 提供的参数自动的在接收者容器中创建一些环境变量,包括源容器的 Dockerfile 中使用 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

例如:

#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_ 开头。

注意的是,如果源容器重启,接收容器中的环境变量信息并不会自动更新,因此,如果要使用源容器的 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 中的信息会自动更新。

更多 Docker 相关教程见以下内容

Docker 安装应用(CentOS 6.5_x64) http://www.linuxidc.com/Linux/2014-07/104595.htm

Ubuntu 14.04 安装 Docker  http://www.linuxidc.com/linux/2014-08/105656.htm

Ubuntu 使用 VNC 运行基于 Docker 的桌面系统  http://www.linuxidc.com/Linux/2015-08/121170.htm

阿里云 CentOS 6.5 模板上安装 Docker http://www.linuxidc.com/Linux/2014-11/109107.htm

Ubuntu 15.04 下安装 Docker  http://www.linuxidc.com/Linux/2015-07/120444.htm

在 Ubuntu Trusty 14.04 (LTS) (64-bit)安装 Docker http://www.linuxidc.com/Linux/2014-10/108184.htm

在 Ubuntu 15.04 上如何安装 Docker 及基本用法 http://www.linuxidc.com/Linux/2015-09/122885.htm

Docker 的详细介绍:请点这里
Docker 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-12/138418.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计2491字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中