Volume:即数据卷。

  • Docker Volume命令能让容器从宿主主机中读取文件,或从容器中持久化数据到宿主主机内,让容器与容器产生的数据分离开来,一个容器可以挂载多个不同的目录。
  • Volume的生命周期是独立于容器的生命周期之外的,即使容器删除了,Volume(数据卷)也会被保留下来,Docker也不会因为这个Volume(数据卷)没有被容器使用而回收。
  • 在容器中,添加或修改这个文件夹里的文件也不会影响容器的联合文件系统。

1、Volume命令说明

通过docker volume --help可以查看Volume命令的详细说明,如下:

[root@192 ~]# docker volume --help

Usage:  docker volume COMMAND

Manage volumes

Commands:
create Create a volume # 创建一个数据卷
inspect # 打印一个或多个数据卷的详细信息
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 volume COMMAND --help可以查看具体命令的详细说明。

2、Volume命令的使用

(1)创建数据卷

命令:docker volume create 自定义名称

[root@192 ~]# docker volume create myVolume
myVolume
[root@192 ~]#

(2)查看本地数据卷列表

命令:docker volume ls

[root@192 ~]# docker volume ls
DRIVER VOLUME NAME
# 下面三个volume是之前练习时所创建的数据卷挂载,提示这样的volume叫匿名挂载
local 0feb6247c783f1b3620b9dff44ace0c4f4071bc7470b55472f87701c916866ad
local 1d729d58cebf058fa9b14022ddd5211d1690fe6c9084e5c0576bb52743c170c1
local 45ae2157b3cd4ea4b04f2308cbb8562f46d56e9cb19a7aedb6391d35c44ac9b9
# 这个是我们上面刚刚创建的数据卷
local myVolume

(3)打印myVolume数据卷的详细信息

命令:docker volume inspect 一个或多个Volume名称

[root@192 ~]# docker volume inspect myVolume
[
{
"CreatedAt": "2021-03-19T15:13:50+08:00",
"Driver": "local",
"Labels": {},
"Mountpoint": "/var/lib/docker/volumes/myVolume/_data",
"Name": "myVolume",
"Options": {},
"Scope": "local"
}
]

说明:

  • 每创建一个Volume,Docker默认会在宿主机的/var/lib/docker/volumes/目录下创建一个子目录,默认情况下目录名是一串UUID。
  • 如果指定了名称,则目录名是Volume名称(例如上面的myVolume)。Volume里的数据都存储在这个子目录的_data目录下。
  • MountPoint属性标识了,该数据卷在宿主机上的路径为/var/lib/docker/volumes/myVolume/_data

    Name属性标识了,数据卷的名称为myVolume

之后我们可以把这个数据卷挂载到一个新的容器中,例如Nginx容器。

执行如下命令:

docker run --rm \
--name Nginx01 \
-p 80:80 \
-v myVolume:/usr/share/nginx/html:ro \
-d nginx

说明:

  • --rm:容器停止后删除该容器。
  • --name Nginx01:给容器命名。
  • -p 80:80:端口映射。
  • -v myVolume:/usr/share/nginx/html:ro:配置刚创建的数据卷到新启动的容器。ro:只读。
  • -d nginx:后台运行该容器。

提示:这里主要是说明Docker Volume命令如何使用,在实际的工作用一般情况下都使用-v配置容器的数据卷挂载。

(4)删除数据卷

命令:docker volume rm 一个或多个Volume名称

# 删除myVolume数据卷
[root@192 ~]# docker volume rm myVolume
myVolume # 查看本地数据卷
[root@192 ~]# docker volume ls
DRIVER VOLUME NAME
local 0feb6247c783f1b3620b9dff44ace0c4f4071bc7470b55472f87701c916866ad
local 1d729d58cebf058fa9b14022ddd5211d1690fe6c9084e5c0576bb52743c170c1
local 45ae2157b3cd4ea4b04f2308cbb8562f46d56e9cb19a7aedb6391d35c44ac9b9
[root@192 ~]#

(5)删除所有未使用的数据卷

命令:docker volume prune

# 删除所有未使用的数据卷
[root@192 ~]# docker volume prune
WARNING! This will remove all local volumes not used by at least one container.
Are you sure you want to continue? [y/N] y # 你确定你要继续吗?
Deleted Volumes: # 删除的数据卷
0feb6247c783f1b3620b9dff44ace0c4f4071bc7470b55472f87701c916866ad
45ae2157b3cd4ea4b04f2308cbb8562f46d56e9cb19a7aedb6391d35c44ac9b9
1d729d58cebf058fa9b14022ddd5211d1690fe6c9084e5c0576bb52743c170c1 Total reclaimed space: 207MB # 回收总空间:207MB # 查看本地的数据,发现一个都没有了。
[root@192 ~]# docker volume ls
DRIVER VOLUME NAME
[root@192 ~]#

提示:只要该数据卷没有被正在运行的容器使用,都会被清楚。

3、具名挂载和匿名挂载

(1)匿名挂载

匿名挂载格式:-v /容器内路径或者-v /宿主机路径:/容器内路径

执行命令如下:

docker run -P --name nginx01 \ # 大P随机指定端口
-v /ect/nginx \ # 匿名挂载
-d nginx

此时查看本地Volume列表:

[root@192 ~]# docker volume ls
DRIVER VOLUME NAME
local 9c4f90cee862dc2c79246c9d1f01119c2ae9082a50f22e12f8b69b9496e3595b
[root@192 ~]#

这个一长串的UUID就是,就是该Volume没有名字,称为匿名挂载。

可以使用docker volume inspect UUID来查看这个Volume的详细信息

[root@192 ~]#  docker volume inspect 9c4f90cee862dc2c79246c9d1f01119c2ae9082a50f22e12f8b69b9496e3595b
[
{
"CreatedAt": "2021-03-19T16:35:13+08:00",
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/9c4f90cee862dc2c79246c9d1f01119c2ae9082a50f22e12f8b69b9496e3595b/_data",
"Name": "9c4f90cee862dc2c79246c9d1f01119c2ae9082a50f22e12f8b69b9496e3595b",
"Options": null,
"Scope": "local"
}
]

(2)具名挂载

具名挂载格式:-v volume名称:/容器内路径或者-v volume名称:/宿主机路径:/容器内路径

执行命令如下:

docker run -P --name nginx02 \ # 大P随机指定端口
-v juming-nginx:/ect/nginx \ # 匿名挂载
-d nginx

此时查看本地Volume列表:

[root@192 ~]# docker volume ls
DRIVER VOLUME NAME
local 9c4f90cee862dc2c79246c9d1f01119c2ae9082a50f22e12f8b69b9496e3595b
local juming-nginx
[root@192 ~]#

我们得到的就是一个具有具体名称的Volume

我们通过具名挂载可以方便的找到某一个数据卷,一般情况下都使用具名挂载。

(3)Docker容器数据卷的默认挂载位置

所有的Docker容器内的卷,在没有指定宿主机目录的情况下,都是在宿主机的/var/nib/docker/vilumes/xxxx/data目录位置挂载数据。

# 进入宿主机docker目录/var/lib/docker/,
# docker的东西都在这个目录中。
[root@192 ~]# cd /var/lib/docker/
[root@192 docker]# ll
总用量 12
drwx--x--x. 4 root root 120 3月 15 02:00 buildkit
drwx-----x. 4 root root 150 3月 19 16:47 containers
drwx------. 3 root root 22 3月 15 02:00 image
drwxr-x---. 3 root root 19 3月 15 02:00 network
drwx-----x. 23 root root 8192 3月 19 16:47 overlay2
drwx------. 4 root root 32 3月 15 02:00 plugins
drwx------. 2 root root 6 3月 19 12:07 runtimes
drwx------. 2 root root 6 3月 15 02:00 swarm
drwx------. 2 root root 6 3月 19 16:30 tmp
drwx------. 2 root root 6 3月 15 02:00 trust
drwx-----x. 4 root root 142 3月 19 16:47 volumes # 查看volumes目录,里边存放的都收本地Docker中的数据卷
[root@192 docker]# ll volumes/
总用量 24
drwx-----x. 3 root root 19 3月 19 16:35 9c4f90cee862dc2c79246c9d1f01119c2ae9082a50f22e12f8b69b9496e3595b
drwx-----x. 3 root root 19 3月 19 16:47 juming-nginx
-rw-------. 1 root root 32768 3月 19 16:47 metadata.db # 进入juming-nginx中的_data目录就能看到nginx的配置文件nginx.conf
[root@192 docker]# cd volumes/juming-nginx/_data/
[root@192 _data]# ls
conf.d fastcgi_params koi-utf koi-win mime.types modules nginx.conf scgi_params uwsgi_params win-utf
[root@192 _data]#

『现学现忘』Docker基础 — 30、Docker中数据卷相关命令的更多相关文章

  1. 『学了就忘』Linux用户管理 — 51、用户管理相关命令

    目录 1.添加用户(useradd命令) 2.设定密码(passwd命令) 3.用户信息修改(usermod命令) 4.删除用户(userdel命令) 5.切换用户身份(su命令) 1.添加用户(us ...

  2. 『学了就忘』Linux用户管理 — 52、用户组管理相关命令

    目录 1.添加用户组 2.删除用户组 3.把用户添加进组或从组中删除 4.有效组(了解) 1.添加用户组 添加用户组的命令是groupadd. 命令格式如下: [root@localhost ~]# ...

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

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

  4. Docker基础修炼2--Docker镜像原理及常用命令

    通过前文的讲解对Docker有了基本认识之后,我们开始进入实战操作,本文先演示Docker三要素之镜像原理和相关命令. 本文的演示环境仍然沿用上一篇文章在本地Centos7中安装的环境,如果你本地没有 ...

  5. 『现学现忘』Docker基础 — 16、Docker中的基本概念和底层原理

    目录 1.Docker的底层原理 2.Docker中常用的基本概念 3.run命令的运行流程 4.为什么Docker比VM快 Docker架构图: 我们依照Docker架构图进行Docker基础概念的 ...

  6. 『现学现忘』Docker基础 — 32、通过DockerFile的方式挂载数据卷

    目录 1.简单了解一下DockerFile 2.通过DockerFile的方式挂载数据卷 (1)创建DockerFile文件 (2)编辑Dockerfile文件 (3)构建Dokcer镜像 (4)启动 ...

  7. 『现学现忘』Docker基础 — 34、DockerFile文件详解

    目录 1.DockerFile文件说明 2.Dockerfile构建过程解析 (1)Docker容器构建三步骤 (2)Dockerfile文件的基本结构 (3)Dockerfile注意事项 (4)Do ...

  8. 『现学现忘』Docker基础 — 10、Docker的安装

    目录 1.前提 2.通过yum安装Docker (1)更新yum包 (2)移除旧的Docker版本 (3)安装必须的软件包 (4)设置稳定yum源仓库 (5)更新yum软件包索引 (6)开始安装Doc ...

  9. 『现学现忘』Docker基础 — 11、Docker安装的问题补充

    目录 1.问题复现 2.解决冲突 3.重新安装docker-ce-selinux 4.安装Docker-ce 5.总结 通过yum安装Docker的时候,安装20版本的Docker没有出现问题,在安装 ...

随机推荐

  1. VUE3 之 动态组件 - 这个系列的教程通俗易懂,适合新手

    1. 概述 暗示效应告诉我们: 巧妙的暗示会在不知不觉中剥夺我们的判断力,对我们的思维形成一定的影响,造成我们行为的些许改变或者偏差. 例如你的朋友说你脸色不太好,是不是病了,此时,你可能就会感觉浑身 ...

  2. shell——wait与多进程并发

    在脚本里用&后台打开多个子进程,用wait命令可以使这些子进程并行执行. 例1: fun1(){ while true do echo 1 sleep 1 done } fun2(){ whi ...

  3. 实现redis哨兵,模拟master故障场景

    由于主从架构无法实现master和slave角色的自动切换,所以在发送master节点宕机时,redis主从复制无法实现自动的故障转移,即将slave 自动提升为新的master.因此,需要配置哨兵来 ...

  4. Linux_shell命令说明

    1.1 pwd命令 该命令的英文解释为print working directory(打印工作目录).输入pwd命令,Linux会输出当前目录. 1.2 cd命令 cd命令用来改变所在目录. cd / ...

  5. Solution -「HNOI 2019」「洛谷 P5293」白兔之舞

    \(\mathcal{Description}\)   Link.   不想概括题意.jpg \(\mathcal{Solution}\)   定义点集 \(S_c=\{(u,v)|v=c\}\):第 ...

  6. [LeetCode]21.合并两个有序链表(Java)

    原题地址: merge-two-sorted-lists 题目描述: 将两个升序链表合并为一个新的 升序 链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. 示例 1: 输入:l1 = [1 ...

  7. 使用MyBatis拦截器后,摸鱼时间又长了。🐟

    场景 在后端服务开发时,现在很流行的框架组合就是SSM(SpringBoot + Spring + MyBatis),在我们进行一些业务系统开发时,会有很多的业务数据表,而表中的信息从新插入开始,整个 ...

  8. ASP.NET Core 6框架揭秘实例演示[09]:配置绑定

    我们倾向于将IConfiguration对象转换成一个具体的对象,以面向对象的方式来使用配置,我们将这个转换过程称为配置绑定.除了将配置树叶子节点配置节的绑定为某种标量对象外,我们还可以直接将一个配置 ...

  9. yaml语法及格式校验

    基本语法 1.yml文件以缩进代表层级关系 2.缩进不允许使用tab只能使用空格 3.空格的个数不重要,只要相同层级的元素左对齐即可 4.大小写敏感 5.数据格式为,名称:(空格)值 也就是说,如果冒 ...

  10. TCP三次握手中SYN,ACK,seq ack的含义

    转至:https://www.cnblogs.com/muyi23333/articles/13841268.html 1.TCP 为什么三次握手而不是两次握手 1.防止已失效的连接请求又传送到服务器 ...