docker容器数据卷

二、docker容器数据卷

什么是容器数据卷

docker的理念回顾

将应用和环境打包成一个镜像
如果数据都在容器中,那么我们容器删除,数据就会丢失!--需求:数据可以持久化
mysql容器删了==等同于删库跑路!--需求:mysql数据可以存储本地或其他地方

所以容器之间可以有一个数据共享的技术! docker容器中产生的数据同步到本地,这就是卷技术!目录的挂载,将我们容器内的目录,挂载到linux上面!

 

总结:容器的持久化和同步操作;容器之间可以数据共享


####使用数据卷

方式一:直接使用命令来挂载 -v
docker run -it -v 主机目录:容器内目录

#测试:
[root@localhost home]# docker run -it -v /home/testdir:/home centos /bin/bash

#启动起来的时候我们可以通过 # docker inspect 容器的id

 

#测试文件的同步 

#再来测试

1.停止容器
2.宿主机上修改文件
3.启动容器
4.容器内的数据依旧是同步的

好处:以后修改只需在本地修改即可,容器内会自动同步

 

实战:安装mysql
mysql数据持久化

#获取镜像
[root@localhost ~]# docker pull mysql:5.7

#运行容器,需要做数据挂载 #安装启动mysql,需要配置密码
#官方测试:docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

#启动我们的
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置
--name 容器名字

[root@localhost ~]# docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=qwe123 --name mysql01 mysql:5.7


# 启动成功之后,我们可以使用mysql_wakebench或者sqlyog连接测试一下
# sqlyog 连接到服务器3310 ----- 3310和容器内的3306映射

#在本地测试创建一个数据库,查看一下映射路径是否OK

假设我们将容器删除 

发现挂载到本地的数据卷依旧没有丢失,实现了容器数据持久化功能!

 

具名挂载和匿名挂载


#匿名挂载

-v 容器内路径
docker run -d -p --name nginx01 -v /etc/nginx

#查看所有volume 的情况
[root@localhost ~]# docker volume ls
DRIVER VOLUME NAME
local 8dc0c5fe99666adb8e3fff37d20d5e499d66442437de71eff202084945eca34c
local 69f787ba8a05ec4f2da4779a89a27f59c3f12b6afb1432255d25e93066b1316d

#这种就是匿名挂载,我们在-v 只写了容器内的路径,没有写容器外的路径


#具名挂载
[root@localhost ~]# docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
3668952cefe87eb7bb9cb5177476a9dcd63389d5f05440d26bbf2ec3adb5bce7
[root@localhost ~]# docker volume ls
DRIVER VOLUME NAME
local 8dc0c5fe99666adb8e3fff37d20d5e499d66442437de71eff202084945eca34c
local 69f787ba8a05ec4f2da4779a89a27f59c3f12b6afb1432255d25e93066b1316d
local juming-nginx


#通过 -v 卷名:容器内路径
#查看一下这个卷

所有的docker容器内的卷,没有指定目录的情况下都是在/var/lib/docker/volumes/***/_data
我们通过具名挂载可以方便的找到我们的一个卷,大多数情况在使用“具名挂载”


# 如何确定是具名挂载还是匿名挂载,还是指定路径挂载!
-v 容器内路径 #匿名挂载
-v 卷名:容器内路径 #具名挂载
-v /宿主机路径:容器内路径 #指定路径挂载


拓展:

#通过-v 容器内路径:ro rw 改变读写权限
ro readonly # 只读
rw readwrite # 可读可写

# 一旦这个设置了容器权限,容器对我们挂载出来的内容就有限定了
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx

#ro 只要看到ro就说明这个路径只能通过宿主机来操作,容器内部是无法操作的!

 

posted @ 2021-12-07 23:44  zhangshan  阅读(53)  评论(0编辑  收藏  举报