【Docker 系列】docker 学习 五,我们来看看容器数据卷到底是个啥

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【Docker 系列】docker 学习 五,我们来看看容器数据卷到底是个啥

【Docker 系列】docker 学习 五,容器数据卷

什么是容器数据卷

思考一个问题,我们为什么要使用 Docker?

主要是为了可以将应用和环境进行打包成镜像,一键部署。

再思考一个问题,容器之间是相互隔离的,如果我们在容器中部署类似 mysql 这样的组件,如果把该容器删除掉,那么 mysql 的数据也会被删掉了,数据丢失了,咱们删库跑路真刺激

事实上,我们可不能让这么有风险的事情存在,因此有了卷技术

卷技术是容器之间可以共享数据的技术,Docker 容器中产生数据,将数据同步到本地

例如咱们将 Docker mysql 容器中的 /usr/mysql 目录挂载到宿主机的/home/mysql 目录

image.png

使用卷技术,我们就可以让数据得以持久化

实际上操作起来就是挂载目录,将 Docker 容器里面的目录,挂载到宿主机上的某个目录,这就可以将数据持久化和同步了, Docker 容器间的数据共享仍然是这样做的

咱们如何使用数据卷?

启动容器的时候,直接使用 -v命令就可以进行数据卷的挂载


docker run -it -v 宿主机目录:容器目录 镜像名

我们来尝试启动一个 nginx,并将宿主机的 /home/test 目录和 nginx 的/home目录挂载起来


#docker run -d -v /home/test:/home nginx

此时我们在宿主机的/home/test目录下建一个 test.txt 并且写入一些字符串,再查看容器的 /home 目录 是否有 test.txt


# 宿主机
root@iZuf66y3tuzn4wp3h02t7pZ:/home/test# echo xiaomotong >> test.txt
# 容器
root@c8405d03a9a1:/home# ls
test.txt
root@c8405d03a9a1:/home# cat test.txt
xiaomotong

我们在容器的/home 目录下创建一个test2.txt 文件,同样写入一些字符串,再查看 宿主机的 /home/test 目录是否有 test2.txt

# 容器
root@c8405d03a9a1:/home# echo xiaozhu >> test2.txt
# 宿主机
root@iZuf66y3tuzn4wp3h02t7pZ:/home/test# ls
test2.txt  test.txt
root@iZuf66y3tuzn4wp3h02t7pZ:/home/test# cat test2.txt
xiaozhu

查看上述效果,果然是挂载 ok,数据确实同步了,哪怕是我们把 docker 容器删除掉,数据也不会丢失

docker inspect 容器ID ,查看一下我们创建的容器的挂载情况

# docker ps
CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS                  NAMES
c8405d03a9a1   nginx     "/docker-entrypoint.…"   9 minutes ago   Up 9 minutes   80/tcp                 nginx2
# docker inspect c8405d03a9a1
[
  ...
  "Mounts": [
            {
                "Type": "bind",
                "Source": "/home/test",
                "Destination": "/home",
                "Mode": "",
                "RW": true,
                "Propagation": "rprivate"
            }
        ],
  ...
]

使用容器数据卷的便利之处:

以后我们只需要修改宿主机里面的目录和文件,即可和容器中的指定目录保持同步

mysql 实战一波

咱们再来一个实战,我们一起来看看数据卷如何使用

下载 5.7 版本的 mysql docker 镜像,也可以下载其他版本,这个没有关系

# docker pull mysql:5.7
5.7: Pulling from library/mysql   # 5.7版本
33847f680f63: Already exists    # 本层级已经之前已经下载过了
5cb67864e624: Pull complete
1a2b594783f5: Pull complete
b30e406dd925: Pull complete
48901e306e4c: Pull complete
603d2b7147fd: Pull complete
802aa684c1c4: Pull complete
5b5a19178915: Pull complete
f9ce7411c6e4: Pull complete
f51f6977d9b2: Pull complete
aeb6b16ce012: Pull complete
Digest: sha256:be70d18aedc37927293e7947c8de41ae6490ecd4c79df1db40d1b5b5af7d9596
Status: Downloaded newer image for mysql:5.7  
docker.io/library/mysql:5.7     # 真实的mysql 镜像地址

启动镜像,直接使用 -v 来挂载目录

使用方式


docker run -it -v 主机目录:容器的目录

开始启动镜像

咱们可以参考 dockerhub 上的文档


image.png

image.png

# docker run  -d -p 8888:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql1 mysql:5.7
23c31b285804cd95130e36ad40d3c07239fe744845ca464b9c80e42c84848bfb
# 解释一下上述命令
-d 后台运行
-p 宿主机端口:容器端口  端口映射
-v 宿主机目录:容器目录  挂载卷
-e 设置环境变量
--name 设置启动容器的名字

咱们可以通过window 的 workbench 来远程连接一下 mysql

我的是云服务器,因此输入云服务器的地址,端口填入 8888 端口

默认用户名是 root , 密码是 123456

image.png

测试连接 ok ,我们可以来进入数据库

image.png

咱们在 workbench 中新建一个数据库

看看这个数据库是否会在我们的宿主机上面有同步

image.png

查看我们挂载宿主机的目录 /home/mysql/data

root@iZuf66y3tuzn4wp3h02t7pZ:/home/mysql/data#ls
auto.cnf    ca.pem           client-key.pem  ibdata1      ib_logfile1  mysql               private_key.pem  server-cert.pem  sys
ca-key.pem  client-cert.pem  ib_buffer_pool  ib_logfile0  ibtmp1       performance_schema  public_key.pem   server-key.pem   test


image.png

果然是有的,再次 nice,这就达到了数据持久化的效果,这就是咱们从认识数据卷到使用数据卷的一个简单流程,咱们可以慢慢的深入下去

具名挂载和匿名挂载

以启动一个 nginx 为例子:

具名挂载:


# docker run -d  --name nginx3 -v JM:/etc/nginx:rw nginx

匿名挂载:


# docker run -d  --name nginx3 -v /etc/nginx:rw nginx

上述的 rw也可以写成ro

  • rw

可读可写

  • ro

只读,只能宿主机才能写

查看数据挂载卷


root@iZuf66y3tuzn4wp3h02t7pZ:/home/mysql# docker volume ls
DRIVER    VOLUME NAME
local     JM    # 具名挂载 ,下面的为匿名挂载
local     bd2b9ea00eb7d95bb69bdd39a63769ce906a0bb17fae2e29b726f9b92cbcb008
local         d67ba49109dfd654173b8d05f8602b99751066483a357c654b63ba46ec72d5c0

查看挂载具体目录


l# docker volume inspect JM
[
    {
        "CreatedAt": "2021-08-04T23:48:05+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/JM/_data",
        "Name": "JM",
        "Options": null,
        "Scope": "local"
    }
]

查看该目录下的挂载文件,是否是和 nginx 容器中的 /etc/nginx目录下内容一致


root@iZuf66y3tuzn4wp3h02t7pZ:/var/lib/docker/volumes/JM/_data# ll
total 36
drwxr-xr-x 3 root root 4096 Aug  4 23:48 ./
drwx-----x 3 root root 4096 Aug  4 23:48 ../
drwxr-xr-x 2 root root 4096 Aug  4 23:48 conf.d/
-rw-r--r-- 1 root root 1007 Jul  6 22:59 fastcgi_params
-rw-r--r-- 1 root root 5290 Jul  6 22:59 mime.types
lrwxrwxrwx 1 root root   22 Jul  6 23:11 modules -> /usr/lib/nginx/modules
-rw-r--r-- 1 root root  648 Jul  6 23:11 nginx.conf
-rw-r--r-- 1 root root  636 Jul  6 22:59 scgi_params
-rw-r--r-- 1 root root  664 Jul  6 22:59 uwsgi_params

果然一毛一样,nice

再来看看 docker 默认的挂载目录 /var/lib/docker/volumes,我们可以看到每一个匿名挂载,和具名挂载的目录和数据都存放于此


root@iZuf66y3tuzn4wp3h02t7pZ:/var/lib/docker/volumes# ll
total 44
drwx-----x  5 root root   4096 Aug  4 23:48 ./
drwx--x--x 13 root root   4096 Aug  3 22:58 ../
brw-------  1 root root 252, 1 Aug  3 22:58 backingFsBlockDev
drwx-----x  3 root root   4096 Aug  1 21:36 bd2b9ea00eb7d95bb69bdd39a63769ce906a0bb17fae2e29b726f9b92cbcb008/
drwx-----x  3 root root   4096 Aug  3 23:32 d67ba49109dfd654173b8d05f8602b99751066483a357c654b63ba46ec72d5c0/
drwx-----x  3 root root   4096 Aug  4 23:48 JM/
-rw-------  1 root root  32768 Aug  4 23:48 metadata.db

我们来小结一下

  • 指定挂载

-v  宿主机的绝对路径:容器路径

  • 具名挂载

-v 卷名:容器路径

  • 匿名挂载

-v 容器路径

参考资料:

docker docs

欢迎点赞,关注,收藏

朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

image.png

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是阿兵云原生,欢迎点赞关注收藏,下次见~

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5天前
|
存储 安全 数据安全/隐私保护
【Docker 专栏】Docker 容器化应用的备份与恢复策略
【5月更文挑战第9天】本文探讨了Docker容器化应用的备份与恢复策略,强调了备份在数据保护、业务连续性和合规要求中的关键作用。内容涵盖备份的重要性、内容及方法,推荐了Docker自带工具和第三方工具如Portainer、Velero。制定了备份策略,包括频率、存储位置和保留期限,并详细阐述了恢复流程及注意事项。文章还提及案例分析和未来发展趋势,强调了随着技术发展,备份与恢复策略将持续演进,以应对数字化时代的挑战。
【Docker 专栏】Docker 容器化应用的备份与恢复策略
|
5天前
|
监控 Kubernetes Docker
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
【5月更文挑战第9天】本文探讨了Docker容器中应用的健康检查与自动恢复,强调其对应用稳定性和系统性能的重要性。健康检查包括进程、端口和应用特定检查,而自动恢复则涉及重启容器和重新部署。Docker原生及第三方工具(如Kubernetes)提供了相关功能。配置检查需考虑检查频率、应用特性和监控告警。案例分析展示了实际操作,未来发展趋势将趋向更智能和高效的检查恢复机制。
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
|
1天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第13天】在微服务架构和容器化部署日益普及的背景下,对Docker容器的监控变得尤为重要。本文将探讨一种构建高效稳定Docker容器监控体系的方法,通过集成Prometheus和cAdvisor工具,实现对容器资源使用情况、性能指标和运行状态的实时监控。同时,结合Grafana进行数据可视化,为运维人员提供直观的分析界面,以便及时发现和解决潜在问题,保障系统的高可用性和稳定性。
15 6
|
2天前
|
存储 安全 开发者
如何删除 Docker 镜像、容器和卷?
【5月更文挑战第11天】
13 2
如何删除 Docker 镜像、容器和卷?
|
4天前
|
NoSQL Redis Docker
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
16 0
|
5天前
|
缓存 关系型数据库 数据库
【Docker 专栏】Docker 与容器化数据库的集成与优化
【5月更文挑战第9天】本文探讨了Docker与容器化数据库集成的优势,如快速部署、环境一致性、资源隔离和可扩展性,并列举了常见容器化数据库(如MySQL、PostgreSQL和MongoDB)。讨论了集成方法、注意事项、优化策略,包括资源调整、缓存优化和监控告警。此外,强调了数据备份、恢复测试及性能评估的重要性。未来,随着技术发展,二者的集成将更紧密,为数据管理带来更多可能性。掌握此技术将应对数字化时代的机遇与挑战。
【Docker 专栏】Docker 与容器化数据库的集成与优化
|
存储 Docker 容器
Docker之5 数据卷管理
Docker数据卷管理
1478 0
|
5天前
|
存储 安全 数据库
【Docker 专栏】Docker 容器内应用的状态持久化
【5月更文挑战第9天】本文探讨了Docker容器中应用状态持久化的重要性,包括数据保护、应用可用性和历史记录保存。主要持久化方法有数据卷、绑定挂载和外部存储服务。数据卷是推荐手段,可通过`docker volume create`命令创建并挂载。绑定挂载需注意权限和路径一致性。利用外部存储如数据库和云服务可应对复杂需求。最佳实践包括规划存储策略、定期备份和测试验证。随着技术发展,未来将有更智能的持久化解决方案。
【Docker 专栏】Docker 容器内应用的状态持久化
|
5天前
|
机器学习/深度学习 监控 Kubernetes
【Docker 专栏】Docker 容器内服务的自动扩展与缩容
【5月更文挑战第9天】本文探讨了Docker容器服务的自动扩展与缩容原理及实践,强调其在动态业务环境中的重要性。通过选择监控指标(如CPU使用率)、设定触发条件和制定扩展策略,实现资源的动态调整。方法包括云平台集成和使用Kubernetes等框架。实践中,电商平台和实时数据处理系统受益于此技术。注意点涉及监控数据准确性、扩展速度和资源分配。未来,智能算法将提升扩展缩容的效率和准确性,成为关键技术支持。
【Docker 专栏】Docker 容器内服务的自动扩展与缩容
|
5天前
|
Java 数据库连接 Docker
【Docker 专栏】Docker 容器内环境变量的管理与使用
【5月更文挑战第9天】本文介绍了Docker容器中环境变量的管理与使用,环境变量用于传递配置信息和设置应用运行环境。设置方法包括在Dockerfile中使用`ENV`指令或在启动容器时通过`-e`参数设定。应用可直接访问环境变量或在脚本中使用。环境变量作用包括传递配置、设置运行环境和动态调整应用行为。使用时注意变量名称和值的合法性、保密性和覆盖问题。理解并熟练运用环境变量能提升Docker技术的使用效率和软件部署质量。
【Docker 专栏】Docker 容器内环境变量的管理与使用