什么是容器数据卷

docker的理念回顾
将应用和环境打包成一个镜像!
数据?如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据可以持久化
MySQL,容器删除了,删库跑路!需求:MySQL数据可以存储在本地!
容器之间可以有一个数据共享的技术!Docker容器中产生的数据,同步到本地!
这就是卷技术!目录的挂载,将我们容器内的目录,挂载到Linux上面!
总结一句话:容器的持久化和同步操作,容器也是可以数据共享的。

使用数据卷

直接使用命令来挂载 -v

  1. docker run -it -v 主机目录:容器内目录
  2. # 测试
  3. [root@localhost home]# docker run -it -v /home/ceshi:/home centos /bin/bash
  4. # 启动成功后可以通过 docker inspect 容器id

image.png
测试文件的同步
image.png
再次测试

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

image.png
好处:以后修改只需要在本地修改,容器内会自动同步。

实战:安装Mysql

思考:mysql的数据持久化问题

  1. # 下载mysql
  2. [root@localhost home]# docker pull mysql:5.7
  3. # 运行容器,需要做数据挂载 安装启动MySQL 需要配置密码,这点需要注意
  4. # 官方命令:$ docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
  5. # 启动MySQL
  6. -d 后台运行
  7. -p 端口映射
  8. -v 卷挂载
  9. -e 环境配置
  10. --name 容器名称
  11. [root@localhost home]# 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
  12. # 启动成功后,用本地工具来连接测试一下
  13. # 本地工具-连接到服务器的3310--和容器内的3306映射
  14. # 在本地从测试创建一个数据库,查看一下我们映射的路径是否ok

假设我们将容器删除,发现我们挂载在本地的数据卷依旧没有丢失,这就实现了容器数据持久化过程。
image.png
image.png

具名挂载和匿名挂载

匿名挂载

  1. -v 容器内路径
  2. docker run -d -p --name nginx 01 -v /etc/nginx nginx
  3. # 查看所有 volume 的情况
  4. [root@localhost data]# docker volume ls
  5. DRIVER VOLUME NAME
  6. local db6d80b1f88ce207e762cad1612f56558e2a254eef9024cc8c3de54ad0311e7e
  7. # 这里发现,这种就是匿名挂载,我们在 -v 只写了容器内的路径,没有写容器外的路径

具名挂载

  1. # 另外启动一个nginx 使用具名挂载的方式
  2. [root@localhost data]# docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
  3. c2f2635b9381e200766bd9e66b81731e9ae7ba1d16928893399b6f23528b5372
  4. [root@localhost data]# docker volume ls
  5. DRIVER VOLUME NAME
  6. local db6d80b1f88ce207e762cad1612f56558e2a254eef9024cc8c3de54ad0311e7e
  7. local juming-nginx
  8. # 通过 -v 卷名:容器内路径
  9. # 查看一下这个卷
  10. [root@localhost data]# docker volume inspect juming-nginx
  11. [
  12. {
  13. "CreatedAt": "2021-06-09T09:06:49+08:00",
  14. "Driver": "local",
  15. "Labels": null,
  16. "Mountpoint": "/var/lib/docker/volumes/juming-nginx/_data",
  17. "Name": "juming-nginx",
  18. "Options": null,
  19. "Scope": "local"
  20. }
  21. ]

所有的docker容器内的卷,没有指定目录的情况下都是在/var/lib/docker/volumes/xxx/_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 就代表只能通过宿主机改变,不能从容器内部改变

```