Docker的数据管理(上)

本文涉及的产品
数据管理 DMS,安全协同 3个实例 3个月
推荐场景:
学生管理系统数据库
简介: 1、管理docker容器中数据2、容器互联(使用centos镜像)

1、管理docker容器中数据:


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


数据卷:


是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,

从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的mount操作。


docker pull centos: 7
注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。
docker run -it --name test6 -v /var/www:/data1 centos:7 bash
#-v选项可以在容器内创建数据卷
ls
echo "this is test6 file" > /data1/test.txt
exit
#返回宿主机进行查看
cd /var/www/
cat test.txt


2387773-20211011160006147-1794567035.png


数据卷容器:


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


#创建一个容器作为数据卷容器
docker run -it --name test66 -v /data1 -v /data2 centos:7 bash      #创建并进入容器
echo "this is test 100" > /data1/test.txt                #容器内创建测试文件1
echo "THIS IS TEST100" > /data2/TEST.txt             #容器内创建测试文件1
#使用--volumes-from来挂载test2容器中的数据卷到新的容器
docker run -it --name test99 --volumes-from test66 centos:7 bash    #创建并进入容器
cat data1/test.txt                          #查看测试数据是否同步
cat data2/TEST.txt


2387773-20211011160019030-2090623478.png


端口映射: 


在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,


实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务


docker run -d --name test1 -P nginx
#随机映射端口( 从32768开始)  大P
docker run -d --name test2 -p 43000:80 nginx
#指定映射端口   小p


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


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


#创建并运行源容器取名web1
docker run -itd -P --name web1 centos:7 /bin/bash
#创建并运行接收容器取名web2,使用--link选项指定连接容器以实现容器互联
docker run -itd -P --name web2 --link web1:web1 centos:7 /bin/bash          #--link容器名:连接的别名
#进web2容器,ping web1
docker exec -it web2 bash
ping web1<br><br>


2387773-20211012160413779-1189528903.png

相关文章
|
1月前
|
关系型数据库 MySQL Docker
【Docker】4、Docker 数据卷
【Docker】4、Docker 数据卷
32 0
|
3月前
|
关系型数据库 MySQL 数据库
百度搜索:蓝易云【【Docker】Docker部署Mysql并设置数据持久化教程】
通过以上步骤,您已经成功地在Docker中部署了MySQL,并设置了数据持久化,确保数据在容器重新启动或迁移时得以保留。
50 0
|
4月前
|
数据管理 数据库 数据安全/隐私保护
数据管理与持久化:深度解析Docker数据卷
Docker 数据卷在容器化应用中扮演着关键角色,它们提供了一种灵活且可持久化的方式来处理应用数据。本文将深入讨论 Docker 数据卷的基本概念、使用方法以及一系列高级应用场景,通过更为丰富和实际的示例代码,帮助大家全面掌握数据卷的使用和管理。
|
6月前
|
关系型数据库 MySQL 数据库
Docker容器数据持久化之Data Volume(数据卷)与容器数据共享(1)
Docker容器数据持久化之Data Volume(数据卷)与容器数据共享(1)
|
5月前
|
NoSQL 关系型数据库 MySQL
Docker-compose封装mysql和redis并初始化数据
Docker-compose封装mysql和redis并初始化数据
131 0
|
4月前
|
Shell Linux Docker
Docker -v 挂载主机目录到容器中(及数据卷容器)
Docker -v 挂载主机目录到容器中(及数据卷容器)
92 0
|
4月前
|
存储 Docker 容器
Docker容器数据卷与数据共享持久化
Docker容器数据卷与数据共享持久化
97 0
|
1月前
|
数据管理 应用服务中间件 nginx
Docker卷和数据管理
Docker卷和数据管理
15 1
|
5月前
|
关系型数据库 MySQL Java
Docker学习重点(6)~容器数据卷
Docker学习重点(6)~容器数据卷
135 0
|
2月前
|
存储 机器学习/深度学习 Cloud Native
深入浅出Docker容器数据卷
深入浅出Docker容器数据卷
38 1