Docker容器化技术(互联机制实现便捷互访)

2024-03-13 23:04

本文主要是介绍Docker容器化技术(互联机制实现便捷互访),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

容器的互联是一种让多个容器中的应用进行快速交互的方式。它会在源和接收容器之间创建连接关系,接收容器可以通过容器名快速访问到源容器,而不用指定具体的IP地址。

1.自定义容器命名

连接系统依据容器的名称来执行。因此,首先需要自定义一个好记的容器命名。虽然当 创建容器的时候,系统默认会分配一个名字,但自定义命名容器有两个好处:

  • 自定义的命名,比较好记,比如一个Web应用容器我们可以给它起名叫web, 一 目 了然;
  • 当要连接其他容器时候(即便重启),也可以使用容器名而不用改变,比如连接web 容器到db容器;
[root@localhost ~]# docker run -d -P training/webapp python app.py
e862877619b6097ed416172e0fb6a077619bc11967ba90e9225cd9a7394974f6
[root@localhost ~]# docker ps -l
CONTAINER ID   IMAGE             COMMAND           CREATED         STATUS         PORTS                     NAMES
e862877619b6   training/webapp   "python app.py"   8 seconds ago   Up 7 seconds   0.0.0.0:32770->5000/tcp   cranky_einstein

在执行docker run的时候如果添加--rm标记,则容器在终止后会 立刻删除。

注意,- -rm 和-d参数不能同时使用。 

2. 容器互联

使用--link参数可以让容器之间安全地进行交互。 

先创建一个新的数据库容器:

[root@localhost ~]# docker run -d --name db training/postgres
4b59ae3d369c8b97494d44cde13ea94596fc2231d4ee993ecaf76473ccc9cc4a

 删除之前创建的web容器:

[root@localhost ~]# docker rm -f web
web

然后创建一个新的web容器,并将它连接到db容器:

[root@localhost ~]# docker run -d -P --name  web --link db:db training/webapp python app.py
39bacf2c70d0ee82162825c344481cf0f2fa539553323854bd76898114e540aa
[root@localhost ~]# docker ps
CONTAINER ID   IMAGE               COMMAND                  CREATED         STATUS         PORTS                     NAMES
39bacf2c70d0   training/webapp     "python app.py"          6 seconds ago   Up 5 seconds   0.0.0.0:32772->5000/tcp   web
4b59ae3d369c   training/postgres   "su postgres -c '/us…"   2 minutes ago   Up 2 minutes   5432/tcp                  db
ea8804cd9847   training/webapp     "python app.py"          4 minutes ago   Up 4 minutes   0.0.0.0:5000->5000/tcp    condescending_panini
e862877619b6   training/webapp     "python app.py"          7 minutes ago   Up 7 minutes   0.0.0.0:32770->5000/tcp   cranky_einstein

 可以看到自定义命名的容器: db 和 web, db 容器的 names 列有 db 也有 web/db。 这 表示 web 容器链接到 db 容器, web 容器将被允许访问 db 容器的信息。

使用 env 命令来查看 web 容器的环境变量:

[root@localhost ~]# docker run --rm --name web2 --link db:db training/webapp env
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=67177e778bc4
DB_PORT=tcp://172.17.0.5:5432
DB_PORT_5432_TCP=tcp://172.17.0.5:5432
DB_PORT_5432_TCP_ADDR=172.17.0.5
DB_PORT_5432_TCP_PORT=5432
DB_PORT_5432_TCP_PROTO=tcp
DB_NAME=/web2/db
DB_ENV_PG_VERSION=9.3
HOME=/root

其中 DB—开头的环境变量是供 web 容器连接 db 容器使用, 前缀采用大写的连接别名。

查看是父容器 web 的 hosts文件 :

[root@localhost ~]# docker run -it --rm --link db:db training/webapp /bin/bash
root@8c694bcccae1:/opt/webapp# 
root@8c694bcccae1:/opt/webapp# 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.5	db 4b59ae3d369c
172.17.0.6	8c694bcccae1

在 web 容器中安装 ping 命令来测试跟 db 容器的连通:

root@8c694bcccae1:/opt/webapp# apt-get install -yqq inetutils-ping
(Reading database ... 18233 files and directories currently installed.)
Removing ubuntu-minimal (1.325) ...
Removing iputils-ping (3:20121221-4ubuntu1.1) ...
Selecting previously unselected package inetutils-ping.
(Reading database ... 18221 files and directories currently installed.)
Preparing to unpack .../inetutils-ping_2%3a1.9.2-1_amd64.deb ...
Unpacking inetutils-ping (2:1.9.2-1) ...
Setting up inetutils-ping (2:1.9.2-1) ...
root@8c694bcccae1:/opt/webapp# ping db
PING db (172.17.0.5): 56 data bytes
92 bytes from 172.17.0.1: Packet Filtered
92 bytes from 172.17.0.1: Packet Filtered
92 bytes from 172.17.0.1: Packet Filtered

这篇关于Docker容器化技术(互联机制实现便捷互访)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/806481

相关文章

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩