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

两个centos容器 绑定了之后数据同步

原文地址:https://www.cnblogs.com/lvshuizhicheng/p/14391625.html