zoukankan      html  css  js  c++  java
  • 以Tomcat+Mysql为例,实现Docker多容器连接

    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中的信息会自动更新。

  • 相关阅读:
    关于HashMap的线程安全问题
    Java利器之UML类图详解
    mongoDB4.0数据库
    requests-html库render的使用
    爬虫最新的库requests-html库总结
    爬虫多次爬取时候cookie的存储用于登入
    requests模块响应体属性和方法重新整理
    Visual Studio 代码补全功能有时候会失效的原因
    C++Primer笔记——文本查询程序(原创,未使用类)
    Clion 常用快捷键
  • 原文地址:https://www.cnblogs.com/jytx/p/5438747.html
Copyright © 2011-2022 走看看