废话不多说直接操作

1.启动一个MySQL测试容器
[root@localhost labs]# docker pull mysql  #下载MySQL镜像
[root@localhost labs]# docker run -d --name mysql1 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql #启动一个测试容器,注意 MYSQL_ALLOW_EMPTY_PASSWORD 参数为使用空密码,需要使用true显示设置
root@localhost labs]# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 6ea6b8b8988a mysql "docker-entrypoint..." seconds ago Up seconds /tcp, /tcp mysql1
2.查看MySQL volume信息(在MySQL dockerfile中定义了VOLUME /var/lib/mysql)
[root@localhost labs]# docker volume ls  #查看当前主机上docker volume
DRIVER VOLUME NAME
local 454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf4b
[root@localhost labs]# docker volume inspect 454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf4b
[
{
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf #在宿主机上的路径
"Name": "454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf4b",
"Options": {},
"Scope": "local"
}
]
3.再创建一个MySQL测试容器并观察volume信息
[root@localhost labs]# docker run -d --name mysql2 -e MYSQL_ALLOW_EMPTY_PASSWORD=true  mysql
c228c2caa839d51f9da356912dc56d3689f43ab8efecb97edb65f5557fb5ef02
[root@localhost labs]#
[root@localhost labs]# docker volume ls
DRIVER VOLUME NAME
local 454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf4b
local 5c10a74e6798a503aa0c7a76412c7d27ab17e1e817843057b19c2acb2829c87b
[root@localhost labs]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORT
c228c2caa839 mysql "docker-entrypoint..." seconds ago Up seconds
6ea6b8b8988a mysql "docker-entrypoint..." seconds ago Up seconds
[root@localhost labs]# docker volume inspect 5c10a74e6798a503aa0c7a76412c7d27ab17e1e817843057b19c2acb2829c87b
[
{
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/5c10a74e6798a503aa0c7a76412c7d27ab17e1e817843057b19c2acb2829c8
"Name": "5c10a74e6798a503aa0c7a76412c7d27ab17e1e817843057b19c2acb2829c87b",
"Options": {},
"Scope": "local"
}
]
4.删除刚刚创建的两个测试容器,查看volume是否还在
[root@localhost labs]# docker rm -f mysql1
mysql1
[root@localhost labs]# docker rm -f mysql2
mysql2
[root@localhost labs]# docker volume ls #在容器被删除时,volume并不会被删除
DRIVER VOLUME NAME
local 454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf4b
local 5c10a74e6798a503aa0c7a76412c7d27ab17e1e817843057b19c2acb2829c87b
5.删除所有volume
[root@localhost labs]# docker volume rm 454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf4b 5c1017e1e817843057b19c2acb2829c87b
454e122fc14e377e8328dbd66fb20751ccf6c0cf55988956bcee20dd2e1fcf4b
5c10a74e6798a503aa0c7a76412c7d27ab17e1e817843057b19c2acb2829c87b
[root@localhost labs]# docker volume ls
DRIVER VOLUME NAME
6.使用-v参数绑定一个volume,并查看volume信息
[root@localhost labs]# docker run -d --name mysql1 -v mysql:/var/lib/mysql -e MYSQL_ALLOW_EMPTY_PASSWORD=true   #使用-v 参数绑定。/var/lib/mysql值于docker VOLUME的值一致
fe98466f9854c14657aa4b2139c060283c965a82e67c436f8a072b6961d0770d
[root@localhost labs]# docker volume ls
DRIVER VOLUME NAME
local mysql
[root@localhost labs]# docker volume inspect mysql
[
{
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/mysql/_data", #可以看到挂载路径名称变为了我们指定的名称
"Name": "mysql",
"Options": {},
"Scope": "local"
}
]
7.进入mysql1容器内部,新建一个库名称为docker,然后退出容器并删除容器
[root@localhost labs]# docker exec -it mysql1 /bin/bash
root@fe98466f9854:/# mysql -u root
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is
Server version: 8.0. MySQL Community Server - GPL Copyright (c) , , Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
rows in set (0.01 sec) mysql> create database docker;
Query OK, row affected (0.00 sec) mysql> show databases;
+--------------------+
| Database |
+--------------------+
| docker |
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
rows in set (0.00 sec) mysql> exit
Bye
root@fe98466f9854:/# exit
exit
[root@localhost labs]# docker rm -f mysql1
mysql1
[root@localhost labs]# docker ps -a
8.查看volume是否还存在
[root@localhost labs]# docker volume ls
DRIVER VOLUME NAME
local mysql
9.新建一个mysql2测试容器,并绑定mysql volume
[root@localhost labs]# docker run -d --name mysql2 -v mysql:/var/lib/mysql -e MYSQL_ALLOW_EMPTY_PASSWORD=true  mysql
29398d828164f046f7f605cfa32028079aab241bcf4fda0f11c4889cbc71036b
[root@localhost labs]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
29398d828164 mysql "docker-entrypoint..." seconds ago Up seconds /tcp, /tcp mysql2
10.进入mysql2容器,查看在mysql1中的库
[root@localhost labs]# docker exec -it mysql2 /bin/bash
root@29398d828164:/# mysql
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is
Server version: 8.0. MySQL Community Server - GPL Copyright (c) , , Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> show databases;
+--------------------+
| Database |
+--------------------+
| docker | #mysql1上新建的docker库mysql2挂载后依然存在
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+

总结:

.在Dockerfile中使用VOLUME关键字可以为镜像定义一个volume卷,在使用镜像创建容器时会自动创建一个,名称默认为一串UUID,使用-v参数则目录名是volume名称。volume里的数据都存储在这个子目录的_data目录下。
.Docker Volume能让容器从宿主主机中读取文件或持久化数据到宿主主机内,让容器与容器产生的数据分离开来。你可以简单地把它理解为linux服务器上的挂载点。一个容器可以挂载多个不同的目录。Volume的生命周期是独立于容器的生命周期之外的,即使容器删除了,volume也会被保留下来,Docker也不会因为这个volume没有被容器使用而回收。在容器中,添加或修改这个文件夹里的文件也不会影响容器的联合文件系统。

数据持久化之Data Volume的更多相关文章

  1. Docker容器的数据卷(data volume),数据卷容器,数据卷的备份和还原。

    Docker容器的数据卷(data volume),数据卷容器,数据卷的备份和还原. 数据卷就是数据(一个文件或者文件夹). Docker的理念之一是将应用与其运行的环境打包,docker容器的生命周 ...

  2. iOS数据持久化 -- Core Data-备用

    Core Data是一个功能强大的层,位于SQLite数据库之上,它避免了SQL的复杂性,能让我们以更自然的方式与数据库进行交互.Core Data将数据库行转换为OC对象(托管对象)来实现,这样无需 ...

  3. iOS数据持久化 -- Core Data

    Core Data是一个功能强大的层,位于SQLite数据库之上,它避免了SQL的复杂性,能让我们以更自然的方式与数据库进行交互.Core Data将数据库行转换为OC对象(托管对象)来实现,这样无需 ...

  4. docker--数据持久化之Data Volume

    使用mysql为例 查看docker hub官方的mysql image 的dockerfile,有这一行:VOLUME /var/lib/mysql -v给volume创建别名 [root@loca ...

  5. Named Volume 在 MySQL 数据持久化上的基本应用

    原文作者:春哥 初识春哥时,春哥是美术设计大咖.后不久,创业并致力于游戏开发,已有3年.从Unity3D到IOS(Swift)开发,从前端开发到后端以及容器技术,从设计开发测试到产品经理以及CEO,已 ...

  6. 22. docker 数据持久化 Data Volume

    1 . 使用场景 在docker 容器被删除的时候  希望数据不丢失 2 . Volume 的使用 * 注意 在 mysql 的 Dockerfile 内 定义了 VOLUME ["var/ ...

  7. [Docker] 容器持久化数据的首选机制 Volume

    Volume 是 docker 容器生成持久化数据的首选机制.bind mounts 依赖主机机器的目录机构,volume 完全由 docker 管理.volume 较 bind mounts 有几个 ...

  8. Docker Swarm volume 数据持久化

    Docker Swarm volume 数据持久化 volume 是将宿主级的目录映射到容器中,以实现数据持久化. 可以用两种方式来实现: volume 默认模式:工作节点宿主机数据同步到容器内. v ...

  9. Docker 容器数据卷(Data Volume)与数据管理

    卷(Volume)是容器中的一个数据挂载点,卷可以绕过联合文件系统,从而为Docker 提供持久数据,所提供的数据还可以在宿主机-容器或多个容器之间共享.通过卷,我们可以可以使修改数据直接生效,而不必 ...

随机推荐

  1. Python - 部分PEP8规范

    写代码就像写字一样,为什么有的人写的字十分漂亮,而有的人写的字过后连自己都不认识,最主要还是从一开始是否对自己严格要求.从现在开始就当自己是个初学者,把代码写漂亮点.以下截取了部分PEP8代码规范,里 ...

  2. 利用Python突破验证码限制

    一.实验说明 本实验将通过一个简单的例子来讲解破解验证码的原理,将学习和实践以下知识点: Python基本知识 PIL模块的使用 二.实验内容 安装 pillow(PIL)库: $ sudo apt- ...

  3. 使用Node.js简单创建一个服务器

    首先,我们要了解Node.js不是一种语言,它只是一个除了浏览器之外的,可以运行js的环境. 其次,Node能做些什么 ? web服务器.  命令行工具.   网络爬虫. 桌面应用程序开发等 3.接下 ...

  4. TOTP算法实现二步验证

    概念 TOTP算法(Time-based One-time Password algorithm)是一种从共享密钥和当前时间计算一次性密码的算法. 它已被采纳为Internet工程任务组标准RFC 6 ...

  5. Python之dict(或对象)与json之间转化

    在Python语言中,json数据与dict字典以及对象之间的转化,是必不可少的操作. 在Python中自带json库.通过import json导入. 在json模块有2个方法, loads():将 ...

  6. if语句,if...else语句的分析

    if语句的反汇编判断 if语句的反汇编判断基本是围绕JCC指令的,如果想要有深刻的理解,可以自行练习JCC指令 执行各类影响标志位的指令 jxx xxxx 1.案例一 mov eax,dword pt ...

  7. docker镜像管理(二)

    docker镜像 docker镜像含有启动容器所需要的文件系统和内容,因此,其用于创建并启动docker容器 docker镜像采用分层构建机制,最底层为bootfs,其之为rootfs bootfs: ...

  8. [日常] git版本回退

    还没有push到远程的时候,版本回退的测试如下 先克隆一个空的测试仓库,这是我自己在gitlab里创建的空仓库git clone http://192.168.1.114:8090/admintsh/ ...

  9. 2. Java程序的运行机制

    一.完成一个Java程序的流程:编辑Java源代码→编译Java程序→运行Java程序 1. 在记事本中编写Java程序,然后保存为.java类型文件(Java源文件) 2. 使用javac命令将源文 ...

  10. 1. java 基本规则

    一.命名规范 1. 类名规范:首字母大写,后面每个单词首字母大写(大驼峰式),HelloWorld 2. 变量名规范:首字母小写,后面每个单词首字母大写(小驼峰式),helloWorld 3. 方法名 ...