深入理解 Docker 容器卷

这篇具有很好参考价值的文章主要介绍了深入理解 Docker 容器卷。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Docker 容器卷是一种强大的功能,可以实现容器之间数据共享和持久化存储。本篇博客将介绍 Docker 容器卷的概念、用途和操作步骤,帮助读者更好地理解和使用容器卷。

一、什么是 Docker 容器卷

  • 容器卷是一种 Docker 提供的数据管理机制,于在容器和宿主机之间共享数据。
  • 容器卷可以提供持久化存储,即使容器被删除或重新创建,数据仍然保留。

二、容器卷的用途

  • 容器之间共享数据:多个容器可以通过容器卷共享数据,实现不同容器之间的数据交互。
  • 容器与宿主机之间共享数据:容器卷可以与宿主机文件系统关联,实现容器内外数据的共享。
  • 数据持久化存储通过容器卷,将器中的数据持久化到宿机上,以防容器故障或删除而丢失数据。

三、容器卷相关命令

docker volume create <volume_name>                          创建容器卷
docker volume ls                                            查看容器卷
docker volume inspect <volume_name>                         查看容器卷详情
docker volume rm <volume_name>                              删除容器卷
docker run -v <volume_name>:<container_path> <image_name>   关联容器卷

四、Docker 容器卷的操作步骤

  1. 创建容卷:使用 docker volume create 命令创建一个容器卷,可以指定名称和选项。
  2. 启动器时关联卷:在 docker run 命令中,使用 -v 参数关联所创建的容器卷。可以指定容器主机路径的映射关系。
  3. 在容器内使用卷:在容器的应用程序中,可以像操作文件系统一样使用容器卷,读取和写入数据。
  4. 管理容器卷:使用 docker volume 命令可以操作容器卷,例如列所有的容器卷、删除不再使用的卷等操作。

五、演示

1、创建容器卷:

`docker volume create 容器卷名称`: 创建默认的 Docker 容器卷,存储在 Docker 管理的卷存储区中,具有持久化存储的特性,适用于容器之间的数据共享,具有较好的移植性

 `docker volume create --opt type=none --opt device=主机地址 --opt o=bind 容器卷名称`:创建与主机地址关联的卷,通过直接关联到主机的路径,实现容器与主机之间的数据共享,更加灵活但不够可移植

2、启动容器时关联卷:

`docker run  -v 容器卷名:对应容器内路径 镜像ID`

`docker run -d -p 8889:6379 -v 容器卷名称:/bin/container --name my-redis redis:latest`-d 是后台运行,-p 是匹配主机和容器端口映射,-v 后面跟容器卷路径,--name容器重命名,redis:latest镜像ID和版本

3、在器内写入数据:

`docker exec my-redis` : 进入容器

`mkdir /bin/container/a.txt` : 容器中创建一个 a.txt文件

4、启动另一个容器并关联同一个卷:

`docker run -d -p 8890:6380-v 容器卷名称:/bin/container --name my-redis2 redis:latest`  创建另一个容器,关联该容器卷

5、查看数据同步性

查看本地 容器卷 和 容器中 数据是否同步

六、总结

1、同一个容器卷可以应用于多个容器,并且数据共享。

例:创建容器卷C,容器A和容器B分别关联了容器卷C,如果容器A在容器卷C中创建了文件,会同步到容器卷C 和 容器 B 中

2、容器被删除后,容器卷数据会保留。

例:创建容器卷C,容器A和容器B分别关联了容器卷C,后期如果容器A和容器B被删除,容器卷C还会保留。

3、数据实时同步

例:创建容器卷C,容器A和容器B分别关联了容器卷C,无论是在容器卷C中添加数据、文件,都会实时同步到容器A和容器B关联的路径汇中,反之亦然。

4、创建容器关联容器卷的时候,也可以直接关联主机地址。(不建议)

例:docker run -v 主机地址:对应容器内路径 镜像ID

优缺点分析:

docker volume create 创建 容器卷易于移植性、容器公用

docker run -v 主机地址:对应容器内路径 镜像ID 不易于移植性、容器公用

参考

Docker Documentation: Manage data in Docker
Docker Documentation: Use volumes文章来源地址https://www.toymoban.com/news/detail-600950.html

到了这里,关于深入理解 Docker 容器卷的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 容器技术,1. Docker,2. Kubernetes(K8s):

    目录 容器技术 1. Docker: 2. Kubernetes(K8s): Docker和Kubernetes 容器的主要应用场景有哪些? 有效的将单个操作系统的资源划分到孤立的组中,以便更好的在孤立的组之间平衡有冲突的资源使用需求,这种技术就是容器技术。 容器技术指通过在物理主机操作系统上创建一个一个

    2024年02月11日
    浏览(71)
  • 容器化(Docker、K8S)部署Elasticsearch + Kibana

    ElasticSearch简介 本次实验目标 实验环境 Docker部署Elasticsearch + Kibana 安装中文分词器插件,配置认证 基本操作 在华为云CCE中部署 使用Logstash进行数据迁移

    2024年01月19日
    浏览(75)
  • K8S容器运行时从Docker切换为Containerd

    K8S从1.24版本起不再支持docker容器引擎,可选的替代品有 containerd 、 cri-o 、 podman 。下面演示将单个node节点的容器引擎从docker切换为containerd的过程。 检查是否已经加载内核模块 overlay 和 br_netfilter 。 如果没有,手动加载内核模块: 检查系统内核参数: 如果没有开启,手动调

    2024年02月09日
    浏览(90)
  • 容器的崛起——Docker与K8s的相爱相杀

    对于K8s启用docker,作为普通开发者的体感是,k8s不就是docker的集群操作吗?k8s弃用docker就像鱼反对水一样不可思议,那么这两个技术究竟是什么关系,Kubernetes 是如何一步步与 Docker 解耦的,请看下文。 向应用代码隐藏分布式架构复杂度、让分布式架构得以成为一种能够普遍

    2023年04月08日
    浏览(78)
  • K8S系列文章 之 容器网络基础 Docker0

    使用 ip addr 命令看一下网卡: 其中lo是本地回环地址,docker0就是docker0地址,也就是docker的地址172.17.0.1。 docker使用的是桥接模式,使用的技术是evth-pair技术,后面会解释。 比如有两个容器,容器A要去访问容器B,该如何访问?使用127.0.0.1吗?还是写docker0地址? 我们运行起一

    2024年02月14日
    浏览(64)
  • K8S自动化运维容器化(Docker)集群程序

    1.什么是K8S K8S全程为Kubernetes,由于K到S直接有8个字母简称为K8S。 版本:目前一般是1.18~1.2.0,后续可能会到1.24-1.26,1.24版本后丢弃了docker(如需要使用需要第三方插件配合),目前最新版本是1.27 官网:https://kubernetes.io GitHub:GitHub - kubernetes/kubernetes: Production-Grade Container Schedul

    2024年02月10日
    浏览(69)
  • ​k8s 1.24 1.25 集群使用docker作为容器

    背景 在新版本Kubernetes环境(1.24以及以上版本)下官方不在支持docker作为容器运行时了,若要继续使用docker 需要对docker进行配置一番。需要安装cri-docker作为Kubernetes容器 查看当前容器运行时 安装docker 安装cri-docker 为kubelet配置容器运行时 关于 https://www.oiox.cn/ https://www.oiox.cn

    2024年02月12日
    浏览(70)
  • 【容器架构】你知道有 Docker 为什么还要 K8s 吗?

    👉 博主介绍 : 博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家,WEB架构师,阿里云专家博主,华为云云享专家,51CTO TOP红人 Java知识图谱点击链接: 体系化学习Java(Java面试专题) 💕💕 感兴趣的同学可以收藏关注下 , 不然下次找不到哟

    2024年02月16日
    浏览(73)
  • K8S最新版本集群部署(v1.28) + 容器引擎Docker部署(下)

    🔼上一集:K8S最新版本集群部署(v1.28) + 容器引擎Docker部署(上) *️⃣主目录:温故知新专栏 🔽下一集:Kubernetes可视化管理工具Kuboard部署使用及k8s常用命令梳理记录 kubectl 是使用 Kubernetes API 与 Kubernetes 集群的控制面进行通信的命令行工具。详见官网安装步骤 📕下载kube

    2024年02月09日
    浏览(53)
  • kubernetes(k8s)大白学习02:容器和docker基础、使用、架构学习

    简单说:容器(container)就是计算机上的一个沙盒进程,它与计算机上的所有其它进程相隔离。 这种隔离是怎么做到的呢?它利用了内核提供的 namespace 和 cgroup 这 2 种技术。这些技术能力在 Linux 中已经存在了很长时间。而 Docker 或容器技术致力于将这些功能更易于使用和更

    2024年02月07日
    浏览(69)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包