docker 容器数据卷
docker 容器卷
什么是容器数据卷
- 如果我们将数据存储在docker容器中,那么如果容器删除了,数据也就丢失了!
- 怎么才能将容器中的数据同步到本地呢?这就是卷技术!目录的挂载,将我们容器的目录挂载到Linux上面!
总结 容器的持久化和同步操作! 容器间也是可以数据共享的!
使用容器卷
# 方式一 直接用命令来挂载 -V
docker run -it -v 主机目录:容器内目录
docker run -it -v /home/ceshi:/home centos /bin/bash
容器起来之后,通过docker inspect 容器id查看 具体的挂载
容器内部/home 下创建了 test.java 文件
发现本机/home/ceshi/下也有 test.java 文件
同样在本地添加文件 容器内也增加文件 发现数据是同步的。以后我们只需要在本地修改配置,容器内的配置会同步更新。
docker部署mysql
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=123456 --name mysql01 mysql:5.7
# -d 后台运行
# -v 卷挂载
# -p 端口映射
# -e 环境设置
# -name容器名字
用数据库工具navicat连接docker里的数据库,用工具创建一个test数据库发现本地机/home/mysql/data/ 下多了test文件
如果将mysql容器删除,发现本地的数据没有丢失,这就实现了容器持久化功能!
具名挂载和匿名挂载
# 匿名挂载
-v 容器内路径!
docker -d -P --name nginx01 -v /etc/nginx nginx
# 查看所有的volume的情况
root@qsrobot:~# docker volume ls
DRIVER VOLUME NAME
local 3b486eac452b11dbcecfa727f20a843f880e337ec8ca4d3f45826926afb9eaab
# 这里发现,这种就是匿名挂载,我们在-v 只写了容器内的路径,没写容器外的路径!
#具名挂载
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
root@qsrobot:~# docker volume ls
DRIVER VOLUME NAME
local juming-nginx
# -v 卷名:容器内路径
#查看一下这个卷
![](https://img2020.cnblogs.com/blog/2298258/202102/2298258-20210209113729726-979550419.png)
所有的docker容器的卷,没有指定目录的情况下都是在/var/lib/docker/volumes/xxx/_
我们通过具名挂载可以方便的找到我们的一个卷,大多数情况在使用的 具名挂载
#如何确定是具名挂载还是匿名挂载,还是指定路径挂载!
-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就说明这个路径只能通过宿主机来操作,容器内部是无法操作的!
数据卷容器
docker run -it --name docker02 --volumes-from docker01 镜像id