『中级篇』数据持久化之Data Volume(34)
2018-09-18 03:31:10
李明
  • 访问次数: 382
  • 注册日期: 2018-07-09
  • 最后登录: 2022-11-17

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

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

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

1240

1240

1240

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

1240

#查看volumesudo docker volume ls#容器的volume的Idsudo docker volume inspect 47d003ff423ad06560cdc6e7892d420e7555753f447855fa1fd5ace8a07ab597

1240

1240

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

1240

  • 删除container 看看volume是否会消失

sudo docker ps
sudo docker stop mysql1 mysql2
sudo docker rm mysql1 mysql2
sudo docker volume ls
sudo docker ps

image.png

image.png

  • 现在的volume 名字不太友好啊,得起个别名

sudo docker volume ls
sudo docker volume rm 06bb873ed273c2957b3798b14ed5b90d2d15af3b921c2d6dd09fd25920eba75f
sudo docker volume rm 47d003ff423ad06560cdc6e7892d420e7555753f447855fa1fd5ace8a07ab597
sudo docker volume ls

1240

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

1240

  • 验证volume生效

mysql容器放入数据,然后删除容器,在创建一个挂在容器,看看数据存在不存在。

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

1240

1240

sudo docker rm -f mysql2
sudo docker volume ls#挂在之前的mysql的volmesudo 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;

1240

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

image