『中级篇』数据持久化之Data Volume(34)

有些容器会自动产生一些数据,为了不让数据随着container的消失而消失,保证数据的安全性。例如:数据库容器,数据表的表会产生一些数据,如果我吧container给删除,数据就丢失。为了保证数据不丢失,有了Volume的存在。
源码https://github.com/limingios/docker No.3 方便学习数据持久化存储

以官方的例子
  • hub.docker.com 搜索mysql,查看对应的Dockerfile,VOLUME /var/lib/mysql

VOLUME的使用

从本次开始我开始用第三方SecureCRT了不再用cmd了

#镜像加速器
curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://b81aace9.m.daocloud.io
#创建一个mysql容器,MYSQL_ALLOW_EMPTY_PASSWORD使用空密码
sudo docker run -d --name mysql1 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql
sudo docker ps

#查看volume
sudo docker volume ls
#容器的volume的Id
sudo docker volume inspect 47d003ff423ad06560cdc6e7892d420e7555753f447855fa1fd5ace8a07ab597

#创建一个mysql2,查看对应的volume
sudo docker run -d --name mysql2 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql 
sudo docker volume ls
sudo docker volume inspect 47d003ff423ad06560cdc6e7892d420e7555753f447855fa1fd5ace8a07ab597

  • 删除container 看看volume是否会消失
sudo docker ps
sudo docker stop mysql1 mysql2
sudo docker rm mysql1 mysql2
sudo docker volume ls
sudo docker ps

image.png

  • 现在的volume 名字不太友好啊,得起个别名
sudo docker volume ls
sudo docker volume rm 06bb873ed273c2957b3798b14ed5b90d2d15af3b921c2d6dd09fd25920eba75f
sudo docker volume rm 47d003ff423ad06560cdc6e7892d420e7555753f447855fa1fd5ace8a07ab597
sudo docker volume ls

#volume的别名是mysql,只向的路径是/var/lib/mysql
sudo docker run -d -v mysql:/var/lib/mysql --name mysql2 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql   
sudo docker volume ls

  • 验证volume生效
    > mysql容器放入数据,然后删除容器,在创建一个挂在容器,看看数据存在不存在。

“` bash
sudo docker exec -it mysql2 /bin/bash
mysql -u root
show databases;
create database docker;
show databases;
exit;
exit
sudo docker ps
sudo docker volume ls

<pre><code class="">![](https://upload-images.jianshu.io/upload_images/11223715-9a7cfcd09d7cc7c2.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

![](https://upload-images.jianshu.io/upload_images/11223715-0b4d1e10c4a5b1fd.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

“` bash
sudo docker rm -f mysql2
sudo docker volume ls
#挂在之前的mysql的volme
sudo docker run -d -v mysql:/var/lib/mysql –name mysql1 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql
sudo docker ps
sudo docker exec -it mysql1 /bin/sh
mysql -u root
#查看mysql数据库中的docker是否存在,结果存在
show databases;

PS:这个是数据持久化的一种方式通过volume的方式。

>>原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!
>>原文链接地址:『中级篇』数据持久化之Data Volume(34)
上一篇: 下一篇:

评论 (1)

  • 『中级篇』数据持久化之Data Volume(34)—服务器托管网| 2018年8月31日

    […] >原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!>原文链接地址:『中级篇』数据持久化之Data Volume(34) […]

  • 发表评论

    电子邮件地址不会被公开。 必填项已用*标注