前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【赵渝强老师】Docker的数据持久化

【赵渝强老师】Docker的数据持久化

原创
作者头像
赵渝强老师
发布2024-08-13 10:12:55
820
发布2024-08-13 10:12:55
举报
文章被收录于专栏:容器技术

  在生产环境中使用Docker时,一方面,往往需要对数据进行保存或者在多个容器之间进行数据共享;另一方面,在Docker的容器被删除销毁后,并不保留容器状态的信息。那么如何实现信息的持久化操作呢?这必然涉及容器的数据管理操作和数据的持久化。

  在Docker容器中,实现数据的管理(或者说实现数据的持久化),主要可以通过两种方式来实现。视频讲解如下:

视频内容

一、数据卷(Data Volumes)

  数据卷的本质其实是一个挂载目录,类似使用Linux的mount命令挂载目录。数据卷可以供一个或多个容器使用,可以在不同的容器之间共享和重用数据卷。对数据卷的修改会立即生效。数据卷与容器彼此独立,对数据卷的更新不会影响镜像。

提示:即使容器被删除,数据卷默认也会一直存在,直到删除数据卷为止。

  在Docker中可以使用-mount和-v两种方式给容器挂载数据卷,下图展示了数据卷与容器的关系。

  下面通过一个示例来演示如何使用Docker的数据卷。

(1)创建一个名为myvolume的数据卷。

代码语言:powershell
复制
docker volume create myvolume

(2)查看所有的数据卷,如下图所示。

代码语言:powershell
复制
docker volume ls

(3)使用“docker inspect volume”命令查看数据卷的详细信息,如下图所示。

代码语言:powershell
复制
docker inspect myvolume

提示:从图中可以看出,myvolume被挂载到了“/var/lib/docker/volumes/myvolume/_data”目录下,即在默认情况下,创建的数据卷将会被自动挂载到宿主机的“/var/lib/docker/volumes/”目录下。

(4)启动一个容器,并使用myvolume数据卷。这里使用了Nginx镜像创建了一个容器,并将容器的80端口映射到了宿主机的1234端口,容器的名称是mynginx。

代码语言:powershell
复制
docker run -d -p 1234:80 --name mynginx --mount type=volume,source=myvolume,target=/usr/share/nginx/html/ nginx

  其中参数如下:

  • --mount:指定在容器启动时挂载数据卷
  • type:指定数据卷挂载的方式

二、数据卷容器(Data Volume Containers)

  数据卷容器是一种特殊的容器,它的作用是用来维护数据卷,它可以在多个容器之间共享数据信息。利用数据卷容器也可以很方便地完成数据迁移。下图展示了数据卷、数据卷容器和容器之间的关系。

  下面通过一个示例来演示如何使用Docker的数据卷容器。

(1)创建一个数据卷容器dbdata,并在其中创建一个数据卷挂载到“/dbdata”下。

代码语言:powershell
复制
docker run -it -v /dbdata --name dbdata centos

(2)在数据卷容器dbdata中生成一些测试文件,执行下面的语句,如下图所示。

(3)创建一个容器db1,并使用--volumes-from来挂载dbdata容器中的数据卷。

代码语言:powershell
复制
docker run -it --volumes-from dbdata --name db1 centos

(4)在容器db1中查看目录“/dbdata”,就可以看到数据卷容器中的数据文件了,如下图所示。

(5)在容器db1的“/dbdata”目录下生成了一个新的文件b.txt。

代码语言:powershell
复制
echo "Hello Docker" > b.txt

(6)创建一个容器db2,并使用参数--volumes-from来挂载dbdata容器中的数据卷。

代码语言:powershell
复制
docker run -it --volumes-from dbdata --name db2 centos

(7)在容器db2中查看目录“/dbdata”,如下图所示。

提示:通过上面示例可以看出,容器db1和db2都挂载同一个数据卷到相同的“/dbdata”目录下。三个容器的任何一方在该目录下的写入,其他容器都可以看到。这样便可以很方便地实现不同容器之间的数据共享,并且,利用这样的方式能很容易地实现容器数据迁移。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、数据卷(Data Volumes)
  • 二、数据卷容器(Data Volume Containers)
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档