Docker 容器数据:持久化

每当从镜像创建容器时,它都会创建一个新容器,除了镜像数据之外没有任何数据

  • 意味着如果在提交更改之前删除容器,我们将丢失数据
  • Docker 应该存在一种将数据的文件系统与容器的文件系统分开的技术
  • 每当创建容器时,也会创建一个文件系统【这是默认的 Linux 文件系统】
  • 尽管 Docker 共享操作系统的内核,但文件系统之间存在分离,不然 Docker 就失去了环境隔离的意义

在 Docker 中我们可以创建卷,并且可以挂载到容器的文件系统中

挂载

让我们来看一个简单的挂载:使用主机文件系统并使用带有运行命令的 -v 标志将其挂载到容器上

  • 语法 docker run -it -v <local-path>:<container-path>[:<flag>] <image>

    • flag 是可选的,比如使用 ro 标志可以实现只读效果
  • 我们使用镜像 python:3.6

#### 先在本地主机中创建一个用于挂载的目录,提示 pwd 可以显示当前路径,添加目录使用 mkdir ####
learn@debian10:~$ pwd
/home/learn
learn@debian10:~$ mkdir test
learn@debian10:~$ ls
apt-sources.sh learn.code-workspace packages.microsoft.gpg test work #### 创建挂载本地主机文件系统的容器 #### # 本地主机的 /home/learn/test 目录挂载到 容器的 /root/work 目录
docker run -it -v /home/learn/test:/root/work python:3.6 #### 结果:我们创建挂载的容器,并进入容器 python 的交互模式 ####
Python 3.6.15 (default, Dec 21 2021, 12:03:22)
[GCC 10.2.1 20210110] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> # 判断容器中是否有 /root/work 目录
>>> import os
>>> os.path.isdir(r'/root/work')
True # 在 /root/work 目录,创建一个 test.txt 文件,写入 'test volume\n' 并退出容器
>>> with open(r'/root/work/test.txt', 'w', encoding='utf-8') as f:
... f.write('test volume\n')
...
11
>>> exit()

我们已经退出容器,容器也停止

# 查看 /home/learn/test 目录变化
learn@debian10:~$ ls /home/learn/test
test.txt
learn@debian10:~$ cat /home/learn/test/test.txt
test volume
  • 在容器中 /root/work 目录创建的 test.txt 以及其中数据被持久化在 /home/learn/test
  • 通过这种方式可以使容器中的数据得到保存,并且 /home/learn/test 挂载到不同容器中可以实现不同容器的数据共享
  • 毕竟 Docker 是对应用级的虚拟化,如果没有共享数据的方法,会导致大量重复数据,至于通信那是另一回事【通过端口映射可以实现不一定是挂载】,所有重复数据是主要问题【通过这种共享解决】
  • 挂载有一些限制,并且依赖于主机的文件系统,如果那个目录被删除,你能猜到后果

Volumes

接下来我们聊一聊 Volumes,上面我们知道主机文件系统绑定挂载存在的限制

  • Volumes 卷是 Docker 空间中创建的,这提供了对 Docker CLI 的更多控制
  • Docker Volumes 功能很明确:主要用于在不同容器内共享数据,而不是与主机和容器共享数据
  • 它的相关操作主要是通过 docker 的 volume 子命令

创建 volume 语法 docker volume create [<volume-name>] 其中卷名称是可选的,如果未指定会随机生成一个唯一 ID,最好指定方便记忆【指明含义,否则别起】

  • 在创建 Docker 卷后通过 docker volume inspect <volume-name> 可以查看卷的信息
learn@debian10:~$ docker volume create test-volume
test-volume
learn@debian10:~$ docker volume inspect test-volume
[
{
"CreatedAt": "2023-04-05T15:35:45+08:00",
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/test-volume/_data",
"Name": "test-volume",
"Options": null,
"Scope": "local"
}
]

使用 test-volume 卷运行容器,语法:docker run -it -v <volume-name>:<container-path>[:<flag>] <image>

  • 创造一个负责数据写入的容器:将 test-volume 卷挂载到 /root/w 目录
learn@debian10:~$ docker run -it --name "write-container" -v test-volume:/root/w python:3.6
Python 3.6.15 (default, Dec 21 2021, 12:03:22)
[GCC 10.2.1 20210110] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> with open(r'/root/w/test.txt', 'w', encoding='utf-8') as f:
... f.write('test volume')
...
11
>>> exit()
  • 创造一个负责只读的容器:将 test-volume 卷挂载到 /root/r 目录
# 这里判断方法比较粗浅,建议可以尝试读取 /root/r/test.txt
learn@debian10:~$ docker run -it --name "read-container" -v test-volume:/root/r:ro python:3.6
Python 3.6.15 (default, Dec 21 2021, 12:03:22)
[GCC 10.2.1 20210110] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import os
>>> os.path.exists(r'/root/r/test.txt')
True
>>> exit()
  • 说明一下:--name 项目是为容器命名,属于可选

对卷的管理:

  • docker volume ls 查看所有卷
  • docker volume rm <volume-name> 删除卷

其实最重要的命令是 docker volume --help

实际上还有种挂载形式 tmpfs

  • 这种方式具有临时性,因为保留在主机内存中,具体内容不大懂,推荐官方 https://docs.docker.com/storage/tmpfs/
  • 主要是应用于临时存储主机或容器可写层中的敏感文件,而且这种方法是不支持共享以及只有 Linux 上可以用

想了解更深,希望有知道的提点一下

mount 选项

这个选项基本统合了上面三种方式,而且这种方式在阅读上更严谨

  • 简单语法是 docker --mount 'type=[volume|bind|tmpfs], [src=<local-path|volume-name>] target=<container-path>', [volume-opt=<key=value>], [readonly|ro], ...

  • type 挂载类型在 volume、bind、tmpfs 中选

  • src 路径或卷【type=tmpfs 可以不指定】

  • target 挂载在容器中的路径

  • volume-opt 选项列表功能比较复杂,可选的

  • readonly 或 ro 可读属性,可选

  • ... 表示的是其他属性,建议去官网查看,或者使用 help

使用 docker inspect <container-name|container-id> 可以查看容器挂载内容,这个只是简单说明,毕竟不熟悉在后面学习再细化

Docker 容器数据:持久化的更多相关文章

  1. Docker 容器数据 持久化(系统学习Docker05)

    写在前面 本来是可以将数据存储在 容器内部 的.但是存在容器内部,一旦容器被删除掉或者容器毁坏(我亲身经历的痛,当时我们的大数据平台就是运行在docker容器内,有次停电后,不管怎样容器都起不来.以前 ...

  2. Docker自学纪实(三)Docker容器数据持久化

    谈起数据卷 我一直觉得是个枯燥无聊的话题 但是通过今天的实操和阅读 我发现其实并不是 其实就像走夜路 没有光明,第一次都是恐惧 但是如果走的次数多了 或者静下心来去克制恐惧 也许就会驾轻就熟或者等到黎 ...

  3. 4.云原生之Docker容器数据持久化介绍与实践

    转载自:https://www.bilibili.com/read/cv15182308/?from=readlist #### 创建一个web容器并创建一个数据卷挂载到容器的/webapp目录下(默 ...

  4. docker容器数据持久化

    将数据从宿主机挂载到容器中的三种方式 1.Volume 2.Bind Mounts 3.tmpfs Volumes:docker管理宿主机文件系统的一部分(/var/lib/docker/volume ...

  5. Docker深入浅出系列 | 容器数据持久化

    Docker深入浅出系列 | 容器数据持久化 Docker已经上市很多年,不是什么新鲜事物了,很多企业或者开发同学以前也不多不少有所接触,但是有实操经验的人不多,本系列教程主要偏重实战,尽量讲干货,会 ...

  6. docker mysql 数据持久化到本地、设置不区别表名大小写-清风柳絮-51CTO博客

    原文:docker mysql 数据持久化到本地.设置不区别表名大小写-清风柳絮-51CTO博客 Docker MySQL 把数据存储在本地目录,很简单,只需要映射本地目录到容器即可 1.加上-v参数 ...

  7. Docker容器数据卷-Volume详解

    Docker中的数据可以存储在类似于虚拟机磁盘的介质中,在Docker中称为数据卷(Data Volume).数据卷可以用来存储Docker应用的数据,也可以用来在Docker容器间进行数据共享.数据 ...

  8. 『现学现忘』Docker基础 — 28、Docker容器数据卷介绍

    目录 1.什么是Docker容器数据卷 2.数据卷的作用 3.数据卷的使用 1.什么是Docker容器数据卷 Docker容器数据卷,即Docker Volume(卷). 当Docker容器运行的时候 ...

  9. docker容器的持久化存储:Volume

    独立于docker容器的持久化存储: 法(1):自动将服务器文件夹挂载到容器内部文件夹/usr/share/nginx/html,这样只修改服务器文件夹下的内容即可对应修改容器内部文件夹的内容 将服务 ...

  10. docker容器数据卷的使用

    什么是容器数据卷 docker的理念回顾 将应用和运行的环境打包形成容器运行,运行可以伴随着容器,但是我们对于数据的要求,是希望能够持久化的! 就好比,你安装一个MySQL,结果你把容器删了,就相当于 ...

随机推荐

  1. 平衡二叉树(AVL)插入结点后的再平衡思路

    理解平衡二叉树 在解决平衡二叉树动平衡问题,我们先来明确什么是平衡二叉树: 平衡二叉树是二叉搜索树的一种特殊情况,所以在二叉搜索树的基础上加上了如下定义: 平衡因子:我们将二叉树中各个结点的左右子树的 ...

  2. nginx获取后端真实IP,添加后端服务器响应时间并记录日志

    nginx获取后端真实IP,添加后端服务器响应时间并记录日志 1.日志定义 log_format nginx '$remote_addr - $remote_user [$time_local] &q ...

  3. nginx使用lua waf防火墙来做防CC配置

    nginx添加lua模块 启动和安装nginx yum install -y nginx systemctl daemon-reload systemctl enable nginx #为了实验方便这 ...

  4. js 求任意两数之间的和

    知识点:函数的传参,函数的返回值 函数的传参 函数的参数包括以下两种类型: 1.形参:在定义函数时,声明的参数变量仅在函数内部可见: 2.实参:在调用函数时,实际传入的值. 示例 我们在定义函数的时候 ...

  5. Java中对的创建与引用

    对象与引用 Java语言中除了基本数据类型以外都属于引用类型 Java中的对象是通过引用对其操作的 class Car{ String name; String color; int price; } ...

  6. 使用nvm安装以及管理多版本node教程

    安装nvm.node.npm 下载nvm安装包,推荐使用1.1.7,我个人使用1.1.8会有中文乱码的报错 点击exe文件,注意修改nvm的安装根目录以及node的安装根目录,后者是以后管理多版本no ...

  7. 从零开始的常用MySQL语句练习大全

    先说一些废话 很多时候深入学习固然很重要,但是想要写下一篇给新手都能看得懂看的很香,并且老鸟可以查漏补缺的的练习博客,还是挺有难度, 所以今天尝试写一些关于MySQL的语句练习大全,供想要从零开始练习 ...

  8. 程序员面试金典-面试题 02.02. 返回倒数第 k 个节点

    题目: 实现一种算法,找出单向链表中倒数第 k 个节点.返回该节点的值. 注意:本题相对原题稍作改动 示例: 输入: 1->2->3->4->5 和 k = 2输出: 4说明: ...

  9. jwt 加密和解密demo

    jwt 加密和解密demo JSON Web Token(JWT)是一个非常轻巧的规范.这个规范允许我们使用 JWT 在用户和服务器之间传递安全可靠的信息.导入jar <dependency&g ...

  10. Elasticsearch如何聚合查询多个统计值,如何嵌套聚合?并相互引用,统计索引中某一个字段的空值率?语法是怎么样的?

    目录 Elasticsearch聚合查询说明 空值率查询DSL Elasticsearch聚合基础知识扩展 Elasticsearch聚合概念 Script 用法 Elasticsearch聚合查询语 ...