Docker之容器数据卷

2021-03-11  本文已影响0人  ljchengx

Docker之安装
Docker之常用命令
Docker之练习
Docker之镜像讲解
Docker之容器数据卷

什么是容器数据卷

Docker理念

讲应用和环境打包成一个镜像

数据?如果数据在容器,我们删除容器,数据也会丢失

需求?

容器之间数据共享的技术

将容器内的目录,挂载到宿主机

容器的持久化和同步操作!容器间的数据也是可以共享的!

使用数据卷

方式一 :直接使用 -v 命令

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

测试
[root@VM-0-11-centos home]# docker run -it -v /home/ceshi:/home centos /bin/bash

[root@01178346279f /]# cd home
[root@01178346279f home]# ls
[root@01178346279f home]# 
[root@VM-0-11-centos home]# ls
ceshi
[root@VM-0-11-centos home]# cd ceshi/
[root@VM-0-11-centos ceshi]# ls

# 通过 inspect 查看内容
[root@VM-0-11-centos ceshi]# docker inspect 01178346279f
image-20210310100135826

这里发现挂载信息

可以测试一下,在容器内创建一个文件然后在宿主机目录下查看 文件是同步的

image-20210310101802876 image-20210310101838385

在宿主机内修改文件,容器内的文件也会进行同步。

这里我们在宿主机修改一下test.java 新增内容 "update in linux"

image-20210310101947932

然后在容器内查看修改的内容:

image-20210310102050025

发现修改的内容,已经同步完成。

总结

双向绑定

实战部署MySQL

# 下载msql
[root@VM-0-11-centos /]# docker pull mysql:5.7

# 运行mysql 需要挂载目录 mysql需要配置密码
# 官方测试 docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

# 启动
# -d 后台运行
# -p 端口映射
# -v 卷挂载
# -e 配置
[root@VM-0-11-centos /]# docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7

# 启动成功 测试连接
# 注意端口是宿主机的3310

# 假设此时删除容器 挂载的数据卷依旧存在

image-20210310104201685

进入目录看看挂载的目录:

image-20210310104423982

具名挂载与匿名挂载

# 匿名挂载
-v 容器内路径
-P 随机映射端口
docker run -d -P --name nginx01 -v /etc/nginx nginx

# 下载完成 查看所有的卷情况
[root@VM-0-11-centos ~]# docker volumes ls

# 这就是匿名挂载  -v只写了容器内部路径
image-20210310143157904
# 具名方式启动nginx
-v 卷名:容器内路径
[root@VM-0-11-centos ~]# docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx

# 查看卷信息 发现出现了具名
[root@VM-0-11-centos ~]# docker volume ls
DRIVER    VOLUME NAME
local     d72cd458fa5407bdbcac6cfa1d110fd0f7821ce48e04454da408390a2f37d380
local     juming-nginx
local     portainer_data

#  查看具名目录 docker volume inspect juming-nginx
[root@VM-0-11-centos ~]# docker volume inspect juming-nginx
[
    {
        "CreatedAt": "2021-03-10T14:34:49+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/juming-nginx/_data",
        "Name": "juming-nginx",
        "Options": null,
        "Scope": "local"
    }
]

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

大多数情况下我们使用具名挂载

-v 容器内路径          # 匿名
-v 卷名:容器内路径      # 具名
-v /宿主机路径:容器内路径 # 指定路径挂载

拓展:

# -v 容器内路径: ro/rw 改变读写权限
ro 只读
rw 可读写

# 一旦设置了权限 容器对我们挂载出来的内容就有限定了!
# ro 代表这个路径只能通过宿主机才能操作 容器内无法操作
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

初识Dockerfile

Dockerfile就是用来构建docker 镜像的文件

命令脚本 先体验一下

# 测试
# mkdir docker-test-volume
[root@VM-0-11-centos home]# mkdir docker-test-volume
[root@VM-0-11-centos home]# ls
ceshi  docker-test-volume  mysql

# 创建一个dockerfile文件

# 文件中的内容
# 指令(大写) 参数 
# 匿名挂载
From centos

VOLUME ["volume01","volume02"] 

CMD echo "----end----"
CMD /bin/bash

# 每个命令都是镜像的一层

# 生成
# [root@VM-0-11-centos docker-test-volume]# docker build -f Dockerfile01 -t ljchengx/centos:1.0 .
  
# 查看 已经生成成功了
[root@VM-0-11-centos docker-test-volume]# docker images
REPOSITORY        TAG       IMAGE ID       CREATED          SIZE
ljchengx/centos   1.0       3e09855b2bc7   47 seconds ago   209MB
nginx             latest    f6d0b4767a6c   8 weeks ago      133MB
centos            latest    300e315adb2f   3 months ago     209MB

# 进入镜像 发现没问题 查看
[root@VM-0-11-centos docker-test-volume]# docker run -it 3e09855b2bc7 /bin/bash
[root@eeaff4c28eb3 /]# ls -l

image-20210310151357249

这里发现我们生成镜像的时候自动挂载的数据卷目录

这个卷和外部卷有同步关系

数据卷容器

多个容器实现数据共享

image-20210310152221125
# docker run -it --name docker01 ljchengx/centos:1.0
image-20210310152732130

启动第二个镜像

docker run -it --name docker02 --volumes-from docker01 ljchengx/centos:1.0
image-20210310153515880

此时我们进入docker01的volume01文件夹创建一个文件

[root@VM-0-11-centos ~]# docker ps
CONTAINER ID   IMAGE                 COMMAND                  CREATED          STATUS          PORTS     NAMES
e6a2ac185979   ljchengx/centos:1.0   "/bin/sh -c /bin/bash"   56 seconds ago   Up 55 seconds             docker02
4f087aa4a58f   ljchengx/centos:1.0   "/bin/sh -c /bin/bash"   9 minutes ago    Up 9 minutes              docker01
[root@VM-0-11-centos ~]# docker attach 4f087aa4a58f
[root@4f087aa4a58f /]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var  volume01  volume02
[root@4f087aa4a58f /]# cd /volume01
[root@4f087aa4a58f volume01]# touch docker01

然后进入docker02查看文件是否同步,此时发现在docker02中出现了docker01创建的文件

[root@VM-0-11-centos ~]# docker ps
CONTAINER ID   IMAGE                 COMMAND                  CREATED          STATUS          PORTS     NAMES
e6a2ac185979   ljchengx/centos:1.0   "/bin/sh -c /bin/bash"   2 minutes ago    Up 2 minutes              docker02
4f087aa4a58f   ljchengx/centos:1.0   "/bin/sh -c /bin/bash"   11 minutes ago   Up 11 minutes             docker01
[root@VM-0-11-centos ~]# docker attach e6a2ac185979
[root@e6a2ac185979 /]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var  volume01  volume02
[root@e6a2ac185979 /]# cd /volume01
[root@e6a2ac185979 volume01]# ls
docker01
[root@e6a2ac185979 volume01]# 

上一篇下一篇

猜你喜欢

热点阅读