Docker数据管理、端口映射、容器互联

目录

[一、Docker 的数据管理:](#一、Docker 的数据管理:)

1.数据卷:

[1.1 宿主机目录/var/www/html 挂载到容器中的/data1:](#1.1 宿主机目录/var/www/html 挂载到容器中的/data1:)

[1.2 测试:](#1.2 测试:)

2.数据卷容器:

[2.1 创建一个容器作为数据卷容器:](#2.1 创建一个容器作为数据卷容器:)

[2.2 挂载a1容器中的数据卷到新的容器:](#2.2 挂载a1容器中的数据卷到新的容器:)

[2.3 测试:](#2.3 测试:)

二、端口映射:

三、容器互联(使用centos镜像):

1.创建并运行源容器取名web1:

2.创建并运行接收容器取名web2:

3.测试:


一、Docker 的数据管理:

管理 Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers)。

1.数据卷:

数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于 Linux 下对目录进行的 mount 操作。

1.1 宿主机目录/var/www/html 挂载到容器中的/data1:

注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。

bash 复制代码
docker run -it --name a1 -v /var/www/html:/data1 centos bin/bash

1.2 测试:

2.数据卷容器:

如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。

2.1 创建一个容器作为数据卷容器:

bash 复制代码
docker run --name a1 -v /data1 -v /data2 -it centos:7 /bin/bash
##可以挂载多个目录

2.2 挂载a1容器中的数据卷到新的容器:

bash 复制代码
 docker run -it --volumes-from a1 --name a2 centos:7 /bin/bash

2.3 测试:

二、端口映射:

在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务。

bash 复制代码
docker run -d --name c1 -P nginx:wzw   #随机映射端口(从32769开始)

docker run -d --name c2 -p 1314:80 nginx:wzw    #指定映射端口

三、容器互联(使用centos镜像):

容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。

1.创建并运行源容器取名web1:

bash 复制代码
docker run -itd -P --name web1 centos:7 /bin/bash	

2.创建并运行接收容器取名web2:

使用--link选项指定连接容器以实现容器互联

bash 复制代码
docker run -itd -P --name web2 --link web1:web1 centos:7 /bin/bash		
	#--link 容器名:连接的别名

3.测试:

bash 复制代码
#进web2 容器, ping web1
docker exec -it web2 bash
ping web1
相关推荐
志栋智能7 小时前
低成本自动化巡检:7×24小时守护业务稳定
运维·网络·自动化
AI自动化工坊8 小时前
DeerFlow 2.0实战指南:生产级AI Agent框架的Docker化部署与并行编排
人工智能·docker·ai·容器·开源
ToB营销学堂8 小时前
MarketUP | B2B 自动化营销实战:如何打破“营-销”数据孤岛,构建高转化线索流?
运维·自动化
CDN3609 小时前
360CDN 全系列产品体验:CDN / 高防 / SDK 游戏盾横向测评
运维·安全·游戏
行者-全栈开发9 小时前
容器化时代来临 - Docker 技术演进与核心价值
运维·docker·容器·cicd·自动化构建·容器化时代
云飞云共享云桌面9 小时前
非标自动化研发成本高?云飞云共享云桌面:1台主机=10台工作站,年省数十万。
大数据·运维·服务器·人工智能·自动化·云计算·电脑
AI自动化工坊9 小时前
GitAgent实战解析:用Docker思想解决AI Agent框架碎片化问题,降低80%迁移成本
人工智能·docker·ai·容器·开源
chehaoman10 小时前
Failed to restart nginx.service Unit nginx.service not found
运维·nginx
Linux运维技术栈10 小时前
生产环境Linux应用目录迁移至LVM独立分区 标准化实战方案
linux·运维·服务器·lvm·逻辑卷
feasibility.11 小时前
SSH Agent Forwarding 与 tmux 排障笔记
linux·运维·服务器·经验分享·笔记·ssh