docker 的理念回顾
将应用和环境打包成一个镜像!
数据?如果都在容器中,那么我们删除容器,数据就会丢失!需求:数据可以持久化
容器之间可以有个数据共享技术!Docker 容器中产生的数据,同步到本地!
这就是卷技术!目录的挂载,将我们的容器内的目录,挂载到 Linux 上面。
总结一句话:容器的持久化和同步操作,容器间也是可以数据共享的。
使用数据卷
方式一:直接使用命令里来挂载,容器内目录
docker run -it -v 支及目录:容器目录
#测试
docker run -it -v /home/ceshi:/home centos /bin/bash 说明:将容器内的/home/ceshi的目录和宿主机的/home映射实现数据共享
#启动起来后我们可以通过 docker inspect 容器 ip 查看
测试文件的同步
好处:我们以后修改只需要本地修改即可,容器内会自动同步。
实战练习:安装mysql
#获取镜像
#[root@xxx]#docker pull mysql:5.7
运行容器,需要做数据挂载!并且安装数据库还要配置密码
#官方测试:docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=secret-pw -d
mysql:tag
启动容器中的mysql
-d 后天启动
-p端口映射
-v卷挂载
-e环境配置
--name 容器名字
说明:启动mysql 做宿主机和容器的端口映射,还有数据卷将容器中的/etc/mysql/cond.d 中的配置信息共享到本地的/home/mysql/conf,将容器中mysql的数据/var/lib/mysql共享到宿主机的/home/mysql/data/,再设置mysql的密码。
#测试:1、启动成功后,用 sqlyog 连接到服务器的3310-----3310和服务器的3306映射,
在本地测试创建一个数据库,再查看一下我们的映射路径是否ok。2、将容器删除再次查看瓜子啊到本地的数据卷是否丢失。
具名挂载和匿名挂载
#匿名挂载
-v 容器内路径
docker run -d -P --name nginx01 -v /etc/nginx nginx
#查看所有路径的 volume 的情况
[root@xxxxx]# docker volume ls
local 9f38292179faa178afcce54d80be99d4ddd68c91d2a6887 0bcece72d2b7ed061
# 这里发现,这种就是匿名挂载,我们再 -v 只写了容器内的路径,没有写容器外的路径!
#具名挂载
[root@xxxxxx]# docker run -d -P--name nginx02 -v juming-nginx:/etc/nginx nginx 95b809564484c8ac87 d65c69643e7e67447f1c77ff9a91b93edec7003692e3a9
[root@xxxxxx]# docker volumes ls
DRIVER VOLUME NAME
1ocal juming-nginx
#通过 -v 卷名:容器内路径
#查看一下这个卷
所有的 docker 容器内的卷,再没有指定目录的情况下都是在/var/lib/docker/voumes /xxxx/_ data
我们通过具名挂载可以方便的找到我们的一个卷,大多数情况下在使用的具名挂载
拓展:
# 通过 -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就说明这个路径只能通过宿主机来操作,容器内部是无法操作!默认是开启读写权限的。