博客
关于我
Docker 入门系列(6)- Docker 互联
阅读量:498 次
发布时间:2019-03-07

本文共 1089 字,大约阅读时间需要 3 分钟。

容器互联机制

容器的互联是让多个容器之间快速交互的重要方式。它通过创建源接收容器之间的连接关系,使接收容器可以通过容器名字直接访问源容器,无需指定具体IP地址。

自定义容器命名

容器的名称在容器管理中至关重要。虽然系统会默认为容器分配一个名字,但自定义容器名称有其必要性:

  • 自定义命名便于记忆
  • 即使容器重新启动,仍可通过容器名进行管理和连接

使用--name标记可以为容器自定义名称。例如:

docker run -d -P --name web training/webapp python app.py

命令执行后可使用以下命令查看容器详情:

docker inspect -f "{Name: \"web\"}" 57/web

需要注意,容器名称必须唯一。如果已存在名为web的容器,执行docker rm -f web后才能重新使用该名称。同时,--rm-d标记不能同时使用。

容器互联

通过--link参数实现容器间安全互联。例如创建一个数据库容器:

docker run -d --name db training/postgres

删除已有web容器:

docker rm -f web

创建新的web容器并连接到db容器:

docker run -d -P --name web --link db:db training/webapp python app.py

此时dbweb容器已建立互联关系。可以通过以下方式查看联接状态:

docker ps -a

容器间互联默认会创建虚拟网络通道,无需映射端口到宿主网络即可实现通信。

Docker在实现容器互联时,会更新环境变量和/etc/hosts文件,以便容器内的应用程序能够通过容器名进行通信。

环境变量是实现容器间互联的重要手段。例如连接到db容器的web容器会收到类似以下环境变量:

DB_PORT=tcp://172.17.0.3:5432DB_NAME=/web/db

这些环境变量使应用程序能够安全地通过网络协议与目标容器通信。

例如,在web容器中执行以下命令可查看相关环境变量:

docker run --rm --name web2 --link db:db training/webapp env

此外,Docker还会在web容器的/etc/hosts文件中添加db容器的IP地址信息:

172.17.0.3	db

这样可以确保web容器内部应用程序能够通过IP地址或容器名与db容器进行通信。

多个容器可以同时连接到一个数据库容器,利用Docker的网络机制轻松管理复杂的容器间通信。

转载地址:http://sckjz.baihongyu.com/

你可能感兴趣的文章
Netty核心模块组件
查看>>
Netty框架内的宝藏:ByteBuf
查看>>
Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
查看>>
Netty源码—2.Reactor线程模型一
查看>>
Netty源码—3.Reactor线程模型三
查看>>
Netty源码—4.客户端接入流程一
查看>>
Netty源码—4.客户端接入流程二
查看>>
Netty源码—5.Pipeline和Handler一
查看>>
Netty源码—5.Pipeline和Handler二
查看>>
Netty源码—6.ByteBuf原理一
查看>>
Netty源码—6.ByteBuf原理二
查看>>
Netty源码—7.ByteBuf原理三
查看>>
Netty源码—7.ByteBuf原理四
查看>>
Netty源码—8.编解码原理一
查看>>
Netty源码—8.编解码原理二
查看>>
Netty源码解读
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty相关
查看>>
Netty遇到TCP发送缓冲区满了 写半包操作该如何处理
查看>>
Netty:ChannelPipeline和ChannelHandler为什么会鬼混在一起?
查看>>