博客
关于我
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/

你可能感兴趣的文章
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>