【Docker】Docker数据的存储

news2024/12/26 11:57:49

默认情况下,在运行中的容器里创建的文件,被保存在一个可写的容器层里,如果容器被删除了,则对应的数据也随之删除了。

这个可写的容器层是和特定的容器绑定的,也就是这些数据无法方便的和其它容器共享。

Docker主要提供了两种方式做数据的持久化:

  • Data Volume:由Docker管理(数据目录/var/lib/docker/volumes/), 持久化数据的最好方式
  • Bind Mount:由用户指定存储的数据具体mount在系统什么位置

Data Volume

准备一个脚本

date.sh

#!/bin/bash

while true
do
    echo `date`
    echo `date` >> /home/morris/dockerfile/volumn/logs/date.log
    sleep 1
done

准备一个镜像

Dockerfile

from alpine:latest

label author=morris

env work_dir /usr/app

workdir $work_dir

copy date.sh .

volume ["/home/morris/dockerfile/volume/logs/"]

entrypoint ["sh", "date.sh"]

构建镜像:

$ docker build -t date:1.0 .
Sending build context to Docker daemon  4.608kB
Step 1/7 : from alpine:latest
 ---> c059bfaa849c
Step 2/7 : label author=morris
 ---> Using cache
 ---> 4a7f368ccac1
Step 3/7 : env work_dir /usr/app
 ---> Using cache
 ---> 2413cf06006b
Step 4/7 : workdir $work_dir
 ---> Using cache
 ---> 1230bcd7bf40
Step 5/7 : copy date.sh .
 ---> Using cache
 ---> 6ad3761a0592
Step 6/7 : volume ["/home/morris/dockerfile/volume/logs/"]
 ---> Using cache
 ---> 82ad0fd1b949
Step 7/7 : entrypoint ["sh", "date.sh"]
 ---> Using cache
 ---> ca25386d02f3
Successfully built ca25386d02f3
Successfully tagged date:1.0

创建容器(不指定-v参数)

启动容器:

$ docker container run --rm date:1.0
Fri Sep 22 02:01:56 UTC 2023
Fri Sep 22 02:01:57 UTC 2023

另外启动一个shell,进入容器中查看日志:

$ docker container exec -it e4 sh
/usr/app # tail -f /home/morris/dockerfile/volume/logs/date.log
Fri Sep 22 02:03:32 UTC 2023
Fri Sep 22 02:03:33 UTC 2023
Fri Sep 22 02:03:34 UTC 2023

此时Docker会自动创建一个随机名字的volume,去存储我们在Dockerfile定义的volume。

可以使用docker container inspect命令查看随机生成的volume名称:

... ...
        "Mounts": [
            {
                "Type": "volume",
                "Name": "b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87",
                "Source": "/var/lib/docker/volumes/b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87/_data",
                "Destination": "/home/morris/dockerfile/volume/logs",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            }
        ],
... ...

可以使用docker volume ls查看所有的volume列表:

$ docker volume ls
DRIVER    VOLUME NAME
local     3dc166ddf9968412b6d9f8050a0b9d84f74a0fae4d8f5d1c55222222ec142c82
local     b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87
local     bc5e8a682761ee129bf98206758d4e6a76df9755f825c61c030330ce78190376
local     d62c8edbe60a80ba8c5d57c678e0badb542ec7ceb6120ce3d0e442c3e6d2f7b7
local     f3bbbca769c38f706f286b08824f6bcee0dfb362931c7bf5d97102f12e11fe4f
local     fc6e4e62f182938fa48954252ecbee4485194dcd1c11d995f25678744ce0300d

可以使用docker volume inspect查看volume的详细信息:

$ docker volume inspect b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87
[
    {
        "CreatedAt": "2023-09-22T10:01:56+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87/_data",
        "Name": "b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87",
        "Options": null,
        "Scope": "local"
    }
]

可以看到volume对应宿主机器上存储的物理地址为/var/lib/docker/volumes/b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87/_data,我们到这个目录查看下:

# cd /var/lib/docker/volumes/b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87/_data

# ll
total 36
drwxr-xr-x 2 root root  4096 Sep 22 10:01 ./
drwx-----x 3 root root  4096 Sep 22 10:01 ../
-rw-r--r-- 1 root root 23867 Sep 22 10:15 date.log

# tail -f date.log
Fri Sep 22 02:15:36 UTC 2023
Fri Sep 22 02:15:37 UTC 2023
Fri Sep 22 02:15:38 UTC 2023
... ...

当容器删除后,这个volume也随之删除了:

$ docker volume inspect b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87
[]
Error: No such volume: b4248ae16a86cb38ebab00105adf3084513578168fca142597c154cc6e5b8e87

创建容器(指定-v参数)

在创建容器的时候通过-v参数我们可以手动的指定需要创建Volume的名字,以及对应于容器内的路径,这个路径是可以任意的,不必需要在Dockerfile里通过VOLUME定义。

比如在创建容器时指定volume的名字为mydate,对应容器的路径为/home/morris/dockerfile/volume/logs

$ docker container run -v mydate:/home/morris/dockerfile/volume/logs --rm date:1.0
Fri Sep 22 02:32:31 UTC 2023
Fri Sep 22 02:32:32 UTC 2023

查看volume列表:

$ docker volume ls
DRIVER    VOLUME NAME
local     mydate

删除容器后volume还存在,不会跟着容器一起删除,这样我们在下次运行新的容器时可以volume的名称继续使用volume中的数据。

Bind Mount

Docker Bind Mounts是一种用于将主机文件或目录挂载到Docker容器中的方法,可以实现容器与主机之间的文件共享。

Data Volume模式只能将/var/lib/docker/volumes/中的目录与Docker容器共享,而Docker Bind Mounts能实现主机中任意文件与容器之间的共享。

由于我这里使用的是WSL中运行的Docker,所以我们可以将Windows中的D盘的docker_data目录映射到一个具体GCC环境的Docker容器中,这样可以在Windows下使用编辑器编辑c语言的源文件,然后使用Docker容器中的GCC环境进行编译:

$ docker run --rm -it -v /mnt/d/docker_data:/usr/app gcc:9.4 bash
root@aedaf7a3e462:/# cd /usr/app/
root@aedaf7a3e462:/usr/app# ls
hello.c

多个机器之间的容器共享数据

官方参考链接 https://docs.docker.com/storage/volumes/#share-data-among-machines

Docker的volume支持多种driver。默认创建的volume driver都是local

$ docker volume inspect mydate
[
    {
        "CreatedAt": "2023-09-22T10:32:31+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/mydate/_data",
        "Name": "mydate",
        "Options": null,
        "Scope": "local"
    }
]

下面我们来看看一个叫sshfs的driver,如何让docker使用不在同一台机器上的文件系统做为volume

主机规划

准备两天Linux机器,之间可以通过SSH相互通信。

  • 192.168.200.10:名称为host1,安装Docker
  • 192.168.200.11:名称为host2,作为数据存储

账号密码都是 root/root

安装插件

host1:192.168.200.10上安装Docker插件vieux/sshfs

$ docker plugin install --grant-all-permissions vieux/sshfs
latest: Pulling from vieux/sshfs
Digest: sha256:1d3c3e42c12138da5ef7873b97f7f32cf99fb6edde75fa4f0bcf9ed277855811
52d435ada6a4: Complete
Installed plugin vieux/sshfs

创建volume

使用类型为vieux/sshfs的driver创建一个名为sshvolume的volume。

$ docker volume create --driver vieux/sshfs -o sshcmd=root@192.168.200.11:/home/logs -o password=root sshvolume

查看volume:

$ docker volume ls
DRIVER               VOLUME NAME
local                mydate
vieux/sshfs:latest   sshvolume

$ docker volume inspect sshvolume
[
    {
        "CreatedAt": "0001-01-01T00:00:00Z",
        "Driver": "vieux/sshfs:latest",
        "Labels": {},
        "Mountpoint": "/mnt/volumes/24ef5f7f94863e87f7802e20f5662e68",
        "Name": "sshvolume",
        "Options": {
            "password": "root",
            "sshcmd": "root@192.168.200.11:/home/logs"
        },
        "Scope": "local"
    }
]

创建容器挂载Volume

创建容器,挂载sshvolume

$ docker container run -v sshvolume:/home/morris/dockerfile/volume/logs --rm date:1.0
Thu Sep 28 07:39:49 UTC 2023
Thu Sep 28 07:39:50 UTC 2023
Thu Sep 28 07:39:51 UTC 2023
Thu Sep 28 07:39:52 UTC 2023

这个文件我们可以在host2上看到:

$ tail -f /home/logs/date.log
Thu Sep 28 07:39:49 UTC 2023
Thu Sep 28 07:39:50 UTC 2023
Thu Sep 28 07:39:51 UTC 2023
Thu Sep 28 07:39:52 UTC 2023

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1126981.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Mybatis-Plus CRUD

💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! Mybatis-Plus CRUD 通用 Service CRUD 封装 IService 接口,进一步封装 CRUD 采用 get 查询、remove 删除 、list 查询集合、page 分页的前缀命名方式区分 …

【Flutter 问题系列第 79 篇】在 Flutter 中使用 ReorderableListView 实现拖拽排序列表组件的功能

这是【Flutter 问题系列第 79 篇】,如果觉得有用的话,欢迎关注专栏。 当前开发环境 Flutter 版本:3.10.5,Dart 版本:3.0.5,操作系统:macOS 文章目录 一:效果演示二:Reor…

RK3568驱动指南|第七期-设备树-第59章 实例分析:CPU

瑞芯微RK3568芯片是一款定位中高端的通用型SOC,采用22nm制程工艺,搭载一颗四核Cortex-A55处理器和Mali G52 2EE 图形处理器。RK3568 支持4K 解码和 1080P 编码,支持SATA/PCIE/USB3.0 外围接口。RK3568内置独立NPU,可用于轻量级人工…

Redis工具

GitHub - tanhuang2016/RedisDesktopManagerFX: 搞一个简单实用的Redis图形化工具

HDMI线EMI超标整改方案

HDMI端口辐射(EMI)超标解决方案_hdmi esd器件对 emi的影响-CSDN博客HDMI端口辐射(EMI)超标解决方案一、HDMI EMC设计要求:1、HDMI EMC设计原理图( 图 一 )2、HDMI元件选型及参数说明:(图一所示&…

企业数字化建设有哪些路线可以选择?

企业数字化建设涉及利用数字技术来提高行业的效率、准确性和协作性。在选择企业实施数字化建设的路线时,应该考虑组织的需求和目标的各个方面。可以考虑以下一些路线: 1.项目管理软件:实施项目管理软件,可以更好地规划、调度和跟…

数据库 MySQL总结以及常见命令总结

一、数据库类型 关系型数据库:MYSQL 非关系型数据库:NoSQL、MongoDB、Cassandra、Dynamo 主流关系数据库: 商用数据库,例如:Oracle,SQL Server,DB2等; 开源数据库,例如…

音乐的数字未来:虚拟演唱会与TikTok的巅峰融合

在数字时代,音乐产业正在经历着革命性的变革。虚拟演唱会与TikTok的融合正引领着音乐的数字未来,为艺术家、粉丝和创作者带来了前所未有的互动性和娱乐体验。本文将深入探讨这一巅峰融合,以揭示音乐产业的新前景。 虚拟演唱会的崛起 虚拟演唱…

【机器学习】支持向量机(实战)

支持向量机(实战) 目录 一、准备工作(设置 jupyter notebook 中的字体大小样式等)二、线性支持向量机(核函数为线性核)三、数据标准化的影响四、软间隔五、非线性支持向量机5.1 手动升维5.2 对比试验&#…

MySQL的索引原理

文章目录 什么是索引?索引的工作原理创建和管理索引索引类型最佳实践总结 🎉欢迎来到数据结构学习专栏~MySQL的索引原理 ☆* o(≧▽≦)o *☆嗨~我是IT陈寒🍹✨博客主页:IT陈寒的博客🎈该系列文章专栏:数据结…

MyBatis篇---第五篇

系列文章目录 文章目录 系列文章目录一、MyBatis 中见过什么设计模式?二、MyBatis 中比如 UserMapper.java 是接口,为什么没有实现类还能调用? 一、MyBatis 中见过什么设计模式? 二、MyBatis 中比如 UserMapper.java 是接口&#…

在10.24这个特殊的日子里,带你详细解读1024!

目录 1.前言 2.重识1024 3.庆祝1024 致谢 1.前言 作为一名程序员,我想大家对于1024这个数字并不陌生。因为 1024 是 2 的 10 次方,与计算机科学紧密相关,所以 10 月 24 日也被称为“程序员节”,这是一个属于每一个程序员…

黔院长 | 邀您一同共筑养生健康项目!

黔院长,作为一家有百年技术传承并致力于打造大健康产业的企业,为更好的践行“为健康而生,助天下无疾”的初心和使命,更好的让健康事业造福百姓,让更多的人能够从这份事业当中获益,现面向全国火热招商&#…

【JAVA学习笔记】35 - 类变量

项目代码 https://github.com/yinhai1114/Java_Learning_Code/tree/main/IDEA_Chapter10/src/com/yinhai/static_ 一、类变量的引出 有一群小孩在玩堆雪人,不时有新的小孩加入,请问如何直到现在共有多少人在玩,编写程序解决 package com.yin…

docker版本的Jenkins安装与更新技巧

因为jenkins/jenkins镜像默认带的jenkins版本比较低,导致安装完以后,很多插件因为版本问题无法安装。以下是最权威,最方便的安装教程。 1. 创建本地挂载目录 mkdir -p /mnt/dockerdata/jenkins/home/2. 修改挂载目录权限 chown -R 1000:10…

PaddleX场景实战:PP-TS在电压预测场景上的应用

时间序列是按照时间发生的先后顺序进行排列的数据点序列,简称时序。时间序列预测即运用历史的多维数据进行统计分析,推测出事物未来的发展趋势。时间序列预测是最常见的时序问题之一,在很多行业都有其应用,且通常时序预测效果对业…

js如何解决跨域问题?

🙂博主:锅盖哒 🙂文章核心:js如何解决跨域问题? 目录 前言:跨域问题的本质 详解:跨域问题的原因和限制 跨域问题的限制包括: 用法:解决跨域问题的方法 1. JSONP(J…

(完全解决)如何输入一个图的邻接矩阵(每两个点的亲密度矩阵affinity),然后使用sklearn进行谱聚类

文章目录 背景输入点直接输入邻接矩阵 背景 网上倒是有一些关于使用sklearn进行谱聚类的教程,但是这些教程的输入都是一些点的集合,然后根据谱聚类的原理,其会每两个点计算一次亲密度(可以认为两个点距离越大,亲密度越…

程序员节1024

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

期 货 分 仓,资 管 分 仓,跟单软件都有哪些特点?

期货分仓软件是一种用于期货交易的软件系统。通过该系统,机构可以在一个主账户中同时使用多个子账户操作多个期货合约,并且可以设置不同资金量的用户不同的开仓比例。 由于目前国内的期货市场对于国际市场的品种还处于不规范阶段:一方面是保证…