深入浅出Docker容器数据卷

简介: 深入浅出Docker容器数据卷

Hello朋友们,又快要一周结束了,利用今天这个休息的时间准备再出一篇云原生的文章,研究下Docker的容器数据卷,因为这个点自己也不是很熟练,因此想利用一篇文章再次深度学习并分享下,如果哪里有写的不妥的地方还请大家多多提醒呀!

1 什么是数据卷

一句话,数据卷就是存放数据的卷(哈哈哈)。但是对于“卷”这个概念,对计算机存储方面掌握不扎实的小伙伴应该会有一些陌生,卷的英文是Volume,在Windows系统中经常会被提及,他的概念类似于分区(Partition),都是基于磁盘来进行动态划分的,可以初步的定义为硬盘上的存储区域,当然卷也分为基本卷、镜像卷、带区卷等做种类型,像RAID 0、RAID 1、RAID 5等常见的磁盘分区阵列也是属于卷的一种。

2 Docker容器数据卷

Docker容器数据卷,我们可以做一下概念你的拆分Docker容器数据卷=Docker的容器的数据卷=Docker的容器的数据的卷,因此它的概念还是基于“卷”的。

因此Docker容器数据卷的作用就是使用了一个命名卷来将数据持久化到我们的数据库中,让我们能清楚的知道容器的数据存放在了哪里,当然在多容器的环境下也能达到使容器数据更加安全,方便管理等目的。

Docker容器数据卷的工作就是将Docker容器数据通过映射进行备份+持久化到本地的主机目录。

3 Docker容器数据卷的挂载使用

Docker将容器卷于宿主机进行挂载一般有三种方式(官方推荐有两种):

  • named volumes:命名卷,也叫具名挂载,持久化数据,不必知道确切的挂载点。
  • bind mounts:绑定挂载,也叫匿名挂载,可以控制主机上的确切挂载点。
  • tmpfs mounts(不建议使用):将容器数据挂载到宿主机的内存中

三种方式的不同点:

推荐的两种进行比较:

命名卷 绑定挂载
挂载在主机的位置 Docker自动选择 自定义
挂载示例(-v命令) my-volume:/usr/local/data /path/to/data:/usr/local/data
用容器内容填充新卷 Yes No
支持卷驱动 Yes No
3.1 命名卷的使用

语法:

docker run -d  -v 卷名:容器内目录  镜像名/id

其他语法:

Usage:  docker volume COMMAND
Manage volumes
Commands:
  create      Create a volume
  inspect     Display detailed information on one or more volumes
  ls          List volumes
  prune       Remove all unused local volumes
  rm          Remove one or more volumes
Run 'docker volume COMMAND --help' for more information on a command.

所有docker容器内的卷,在未指定主机内目录时,都在:/var/lib/docker/volumes/卷名/_data 下,可通过具名挂载可以方便的找到卷,因此广泛使用这种方式进行挂载。

3.2 绑定挂载的使用

示例:

# 挂载命令
[root@iZ1608aqb7ntn9Z 20210806]# docker run -it -v /opt/Docker/20210806/:/opt centos /bin/bash
# 进入到容器内部
[root@e749444d0ee1 /]# cd opt/
[root@e749444d0ee1 opt]# ls -l
total 0
-rw-r--r-- 1 root root 0 Aug  6 03:35 ymx
# 查看本机
[root@iZ1608aqb7ntn9Z ~]# cd /opt/Docker/20210806/
[root@iZ1608aqb7ntn9Z 20210806]# ll
总用量 0
-rw-r--r-- 1 root root 0 8月   6 11:35 ymx 
# docker inspect [容器名或ID] 查看挂载
[root@iZ1608aqb7ntn9Z 20210806]# docker inspect e749444d0ee1 
......
     "Mounts": [
            {
                "Type": "bind",
                "Source": "/opt/Docker/20210806",  # 对应主机的源目录
                "Destination": "/opt",    # 容器中的目录
                "Mode": "",
                "RW": true,
                "Propagation": "rprivate"
            }
        ],
......

4 小总结

命名卷是将数据持久保存在Docker容器和服务中的首选方法。命名卷的一些适用于:

  • 在多个运行中的容器之间共享数据。容器停止或删除时,该卷仍然存在,并且多个容器可以同时挂载相同的卷
  • 数据备份

绑定挂载适用于:

  • 将配置文件从主机共享给容器。
  • 在Docker主机上的开发环境和容器之间共享源代码或构建工件。
相关文章
|
15天前
|
Docker 容器
进入Docker容器中
进入Docker容器中
31 2
|
4天前
|
关系型数据库 MySQL Linux
docke数据卷容器
docke数据卷容器
8 0
|
4天前
|
Linux Docker 容器
docker 容器常用命令
docker 容器常用命令
8 0
|
12天前
|
Kubernetes 网络协议 Docker
Docker 容器的DNS
Docker 容器的DNS
21 1
|
15天前
|
关系型数据库 MySQL Nacos
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
41 1
|
19天前
|
监控 数据可视化 虚拟化
Docker容器常用命令笔记分享
Docker容器常用命令笔记分享
47 2
|
25天前
|
存储 Kubernetes 搜索推荐
作为k8s容器运行时,containerd跟docker的对比
作为k8s容器运行时,containerd跟docker的对比
173 0
作为k8s容器运行时,containerd跟docker的对比
|
1月前
|
Java Go 开发者
Docker容器技术简介及其与Go语言的结合点
【2月更文挑战第23天】本文首先概述了Docker容器技术的核心概念和优势,接着探讨了Go语言与Docker容器技术的结合点。通过阐述Docker的轻量级、可移植性和版本控制等特性,以及Go语言在容器化应用中的优势,本文旨在说明两者结合能够实现更高效、灵活的应用开发和部署。
|
1月前
|
Oracle 关系型数据库 数据库
|
1月前
|
开发者 Docker Python
深入浅出:使用Docker容器化部署Python Web应用
在当今快速发展的软件开发领域,Docker作为一个开放平台,为开发者提供了将应用打包在轻量级、可移植的容器中的能力,从而简化了部署和管理应用程序的复杂性。本文将通过一个简单的Python Web应用示例,引导读者理解Docker的基本概念、容器化的优势以及如何使用Docker来容器化部署Python Web应用。我们将从零开始,逐步探索创建Dockerfile、构建镜像、运行容器等关键步骤,旨在为读者提供一个清晰、易于理解的指南,帮助他们掌握使用Docker容器化部署应用的技能。