Docker 容器数据卷

本文详细介绍了Docker容器数据卷的使用,包括如何通过-v命令挂载数据卷实现数据持久化,以及如何在MySQL容器中配置数据卷以确保数据库数据的安全。通过具名和匿名挂载的对比,展示了数据卷在容器间数据共享和权限控制的作用。最后,通过实例演示了如何在删除MySQL容器后,数据卷仍能保持数据,实现了容器数据的持久化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 容器数据卷

docker的理念:将应用和环境打包成一个镜像!

思考:如果数据都在容器中,那么我们容器删除,数据就会丢失!---> 需求:数据可以持久化

MySQL容器,如果容器删除了,删库跑路!---> 需求:MySQL数据可以存储在本地!

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

总结一句话:容器的持久化和同步操作!容器间也是可以数据共享的!

2 使用数据卷

2.1 直接使用命令挂载 -v

格式:docker run -it -v 主机目录:容器内目录 -p 主机端口:容器内端口

命令:docker run -it -v /home/test:/home centos /bin/bash

打开主机 /home 目录,查看目录下的所有文件,然后使用命令挂载,挂载成功之后退出容器,再次查看 /home 目录下的所有文件,多了一个 test 文件夹

注:为了方便同时查看主机、容器下的文件,再打开一个终端(减少进入、退出容器操作)

启动成功之后,在主机可以查看容器的元数据

命令:docker inspect 容器id

找到挂载信息

查看两个目录下的内容是否一致

测试文件的同步:在容器的目录下创建文件 test.py,然后查看主机目录下内容是否发生变化

再次测试

停止容器运行

在主机上添加 test.py 文件内容为:hello, Apollo!

重新启动容器,并进行文件查看

容器内的数据依旧是同步的

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

3 实战:安装mysql

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

  • 下载 mysql 镜像

命令:docker pull mysql:5.7

  • 安装启动mysql,需要配置密码的,这是要注意点!

官方启动:docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

  • 运行 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 后台运行
  • -p 端口映射
  • -v 卷挂载
  • -e 环境配置
  • -- name 容器名字

  • 远程连接测试

命令:mysql -h192.168.141.130 -P3310 -uroot -p123456

 

  • 查看主机文件系统

  • 在本地测试创建一个数据库,查看一下我们映射的路径是否ok!

创建数据库命令:create database test charset=utf8;

  • 查看主机文件系统,多了一个 test 文件

  • 删除 mysql 容器

命令:docker rm -f 容器id

先别跑路啊~~~ 等一下~~~

  • 再次确认,mysql 容器已删

命令:docker ps -a

别跑啊~~~ 再等一下~~~ 

  • 打开主机进行数据查看

不用跑了,哈哈~~ 

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

4 具名和匿名挂载

  • 匿名挂载 -v 容器内路径!

命令:docker run -d -P --name nginx01 -v /etc/nginx nginx

  • 查看所有的volume的情况

命令:docker volume ls

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

  • 具名挂载 -v 卷名:容器内路径

命令:docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx

  • 查看所有的volume的情况

命令:docker volume ls

  • 查看一下这个卷

命令:docker volume inspect juming-nginx

所有的 docker 容器内的卷,没有指定目录的情况下都是在 /var/lib/docker/volumes/xxxx/_data 下

如果指定了目录,docker volume ls 是查看不到的。

  • 进去这个目录进行查看

可以通过具名挂载可以方便的找到任何一个卷,大多数情况下都在使用具名挂载

  • 如何确定是具名挂载还是匿名挂载,还是指定路径挂载

-v 容器内路径        # 匿名挂载

-v 卷名:容器内路径        # 具名挂载

-v /宿主机路径:容器内路径        # 指定路径挂载 docker volume ls 是查看不到的

5 拓展

通过 -v 容器内路径:ro rw    改变读写权限

ro  # readonly  只读
rw  # readwrite  可读可写

docker run -d -P --name nginx05 -v juming:/etc/nginx:ro nginx

docker run -d -P --name nginx05 -v juming:/etc/nginx:rw nginx

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


如果对您有帮助,赏口饭吃❤谢谢老板❤ 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值