使用数据卷管理数据 | Docker 系列

简介: 众所周知,容器是随时创建随时删除的,那删除时容器里的数据怎么办呢?每次手动备份出来?当然不需要,Docker 非常贴心的提供了数据持久化方案,叫数据卷 volume。

众所周知,容器是随时创建随时删除的,那删除时容器里的数据怎么办呢?每次手动备份出来?当然不需要,Docker 非常贴心的提供了数据持久化方案,叫数据卷 volume。

使用 volume 有四大优势:

  • volume 可以在容器之间以及容器和主机之间共享和重用。
  • volume 在某一挂载的位置被修改,所有使用该 volume 的地方都会同时更新。
  • volume 的更新不会影响镜像。
  • volume 会一直存在,直到没有任何容器使用它,才能使用 docker volume rm [volumes名字] 命令删除。

可以看到,除了数据持久化之外,还有很重要的一个点是同步主机的文件到容器,并能够实时更新。这样就可以把源代码目录挂载到容器中,当有代码需要修改时,直接改本地代码就自动同步到容器了,在开发测试时非常方便。


创建数据卷


使用 docker volume create 命令创建数据卷:


$ docker volume create --name test
复制代码


查看数据卷


使用 docker volume ls 命令查看数据卷列表:


$ docker volume ls
DRIVER              VOLUME NAME
local               test
复制代码


使用 docker volume inspect 查看数据卷详情:


$ docker volume inspect test
[
    {
        "CreatedAt": "2020-06-22T10:25:46Z",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/test/_data",
        "Name": "test",
        "Options": {},
        "Scope": "local"
    }
]
复制代码


从详情就能看出来,持久化的数据都在 /var/lib/docker/volumes 目录下了。

测试这个地方的时候还出现了一点小插曲,在 Linux 下完全没问题,但在我自己的 Mac 电脑上,虽然详情已经显示挂载目录了,但 cd 过去却怎么也找不到这个目录。

原因在于,在 Mac 上,Docker 启了一个虚拟机来运行实际的 Docker 进程,那么怎么登录到 Docker 虚拟机呢?使用下面这条命令:


$ screen ~/Library/Containers/com.docker.docker/Data/vms/0/tty
复制代码


如果 docker 版本小于 18.06,使用下面的命令:


$ screen ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/tty
复制代码


执行完命令之后会到一个新的界面,按回车键就进入 Docker 虚拟机了,这下目录就找到了。


docker-desktop:~#
docker-desktop:~# cd /var/lib/docker/volumes/
docker-desktop:/var/lib/docker/volumes# ls
metadata.db  test
复制代码


绑定数据卷


启动容器时可以使用 -v 主机:容器 进行数据卷绑定:


$ docker run -d -v test:/root centos /bin/sh -c "while true; do echo hello world; sleep 1; done"
$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
75f5a72a2f21        centos              "/bin/sh -c 'while t…"   44 hours ago        Up 44 hours                             charming_curie
复制代码


查看容器详情,可以看到具体的绑定信息:


$ docker inspect 75f
...
       "Mounts": [
            {
                "Type": "volume",
                "Name": "test",
                "Source": "/var/lib/docker/volumes/test/_data",
                "Destination": "/root",
                "Driver": "local",
                "Mode": "z",
                "RW": true,
                "Propagation": ""
            }
        ],
...
复制代码


其中,主机目录可以是 volume 名称,也可以具体路径,例如:


$ docker run -d -v /home/test:/root centos /bin/sh -c "while true; do echo hello world; sleep 1; done"
复制代码


这样,对应目录下的文件变更都会得到同步。


删除数据卷


使用 docker volume rm 命令来删除数据卷。

使用 docker volume prune 命令来清理无用的数据卷。


据卷容器


如果要在多个容器之间共享数据,可以使用数据卷容器。说白了就是启一个容器,这个容器专门来供其他容器挂载使用。

首先,创建一个容器 dbdata,并创建一个数据卷挂载到 dbdata:


$ docker run -it -v /dbdata --name dbdata centos
复制代码


使用 --volumes-from 参数启动其他容器:


$ docker run -it --volumes-from dbdata --name db1 centos
$ docker run -it --volumes-from dbdata --name db2 centos
复制代码


这样就可以了,三个容器,只要有一个容器的 dbdata 目录有变化,其他容器都可以同步。


目录
相关文章
|
1月前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
140 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
1月前
|
关系型数据库 数据管理 应用服务中间件
【赵渝强老师】Docker的数据持久化
在生产环境中使用Docker时,为了实现数据的持久化和共享,可以通过数据卷(Data Volumes)和数据卷容器(Data Volume Containers)两种方式来管理数据。数据卷是一个独立于容器的挂载目录,可以跨多个容器共享和重用。数据卷容器则是一种特殊容器,用于维护数据卷,便于数据迁移和共享。本文通过示例详细介绍了这两种方法的使用步骤。
|
2月前
|
存储 Kubernetes Docker
|
2月前
|
存储 安全 数据管理
Docker中实现数据持久化
【10月更文挑战第8天】
50 1
|
2月前
|
存储 数据库 Docker
|
2月前
|
存储 安全 Docker
docker中数据持久化(Volumes)
【10月更文挑战第3天】
69 4
|
2月前
|
存储 Kubernetes 数据库
docker数据持久化问题
【10月更文挑战第4天】
35 2
|
2月前
|
关系型数据库 MySQL 数据库
使用Docker部署的MySQL数据库,数据表里的中文读取之后变成问号,如何处理?
【10月更文挑战第1天】使用Docker部署的MySQL数据库,数据表里的中文读取之后变成问号,如何处理?
73 3
|
3月前
|
存储 数据管理 应用服务中间件
Docker的数据管理实战篇
关于Docker数据管理实战的教程,涵盖了Docker数据卷的使用、特点、场景以及数据卷容器的概念和应用。
71 13
Docker的数据管理实战篇
|
4月前
|
存储 Docker 容器
在Docker中,容器退出后,通过docker ps命令查看不到,数据会丢失么?
在Docker中,容器退出后,通过docker ps命令查看不到,数据会丢失么?