博客
关于我
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工作笔记0011---Channel应用案例2
查看>>
Netty工作笔记0013---Channel应用案例4Copy图片
查看>>
Netty工作笔记0014---Buffer类型化和只读
查看>>
Netty工作笔记0020---Selectionkey在NIO体系
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>
Netty工作笔记0025---SocketChannel API
查看>>
Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
查看>>
Netty工作笔记0050---Netty核心模块1
查看>>
Netty工作笔记0057---Netty群聊系统服务端
查看>>
Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>
Netty工作笔记0070---Protobuf使用案例Codec使用
查看>>
Netty工作笔记0077---handler链调用机制实例4
查看>>
Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
查看>>
Netty工作笔记0085---TCP粘包拆包内容梳理
查看>>
Netty常用组件一
查看>>
Netty常见组件二
查看>>
netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
查看>>
Netty心跳检测机制
查看>>
Netty核心模块组件
查看>>