Docker学习笔记-3

本文介绍了Docker容器数据卷的概念,如何使用-v命令进行数据挂载,实战演示了MySQL的持久化配置,区分了具名挂载和匿名挂载,并强调了数据卷在配置文件管理和数据持久化中的优势。

容器数据卷技术

什么是容器数据卷

docker理念:
将一个应用所需的环境和代码打包成一个镜像。

在此过程中出现的场景:
**数据是否也在容器中存储?**如果数据在容器中存储,当容器删除,数据也就没有了!!
需求:数据的可持久化

例如MySQL的部署,如果镜像删了,mysql内的数据也就丢失?需求:数据可以存储到本地

容器之间有一个数据共享的技术!Docker容器中产生的数据同步到本地!这就是卷技术,目录的挂载,将容器内部的目录挂载到Linux的目录中。
在这里插入图片描述

**总结:**卷技术可以完成容器的持久化和同步操作!容器之间也是可以数据共享的!

使用数据卷
方式一:直接使用命令来挂载 -v

docker run -it -v 主机目录:容器内目录 容器id

#测试
[root@iZbp15mbkzmyf9l6lx443nZ //]# docker run -it -v /home/juan-ceshi:/home centos /bin/bash

#启动起来之我们可以通过:docker inspect 容器id   查看具体挂载的详细挂载信息,如下图

在这里插入图片描述

测试文件的同步过程:
在挂载后的容器内目录中创建test.java,查看与之对应的linux下挂载的目录,test.java文件已经同步过来。
在这里插入图片描述

再来测试:

  1. 停止这个cents容器
  2. 在linux的挂载目录上修改test.java文件
  3. 启动容器,查看容器中挂载的目录下的test.java
  4. 观察发现容器内的文件也是同步的
    在这里插入图片描述

使用容器卷的好处:
对于一些配置文件等(例如nginx的配置文件),以后我们修改只需要在本地对应的挂载目录中进行修改,容器会自动同步到对应的容器内部的挂载目录!

实战:安装mysql

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

# 获取镜像
[root@iZbp15mbkzmyf9l6lx443nZ //]# docker pull mysql:5.7
# 运行容器,需要做数据挂载,安装启动mysql的时候需要配置密码的
# 官方测试docker启动mysql的时候需要配置密码
-e MYSQL_ROOT_PASSWORD=


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

[root@iZbp15mbkzmyf9l6lx443nZ //]# docker run -d -p 4406:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=mzc277171 --name mysql01 mysql:5.7
e8bd73b8ac07754be746810fb1528fc5ccd281cf057afa5b0ed68728e396116f

# 启动成功后本地用sql的客户端进行连接,测试是否连接成功

具名挂载和匿名挂载

#匿名挂载
-v 容器内路径
docker run -d -P --name nginx1 -v /etc/nginx nginx

#查看所有 volume情况
[root@iZbp15mbkzmyf9l6lx443nZ //]# docker volume ls
DRIVER              VOLUME NAME
local               17327107c6f42108a7bac35e7236ea42d0ae74ecaec02b17a532192707e8d05c
local               ccfa89beffecacebf7c33f209cc542af65ae291973b6db342cfde1589a2197b8



#具名挂载
docker run -d -P --name nginx1 -v juming-nginx:/etc/nginx nginx
#通过-v 卷名:容器内路径

所有的docker容器内的卷,没有指定目录的情况下是在“/var/lib/docker/volumes/xxxx”
在这里插入图片描述

我们通过具名挂载,可以方便的找到我们的一个卷,大多数情况下我们使用的是具名挂载。

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

拓展:

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

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

#ro 只要看到ro就说明这个路径只能通过宿主机进行操作,容器内部是无法操作的。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

良缘白马

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值