数据卷技术

  • 数据卷手动挂载

  • 数据卷容器

part1:数据卷挂载方式

数据卷手动挂载

-v 主机目录:容器目录  #核心参数

#示例

docker run -it --name=centos_test -v /home/wangxun/centos_test:/home centos /bin/bash

docker inspect 容器id  #查看容器的挂载卷是否挂载成功

数据卷手动挂载练习:安装mysql

手动挂载数据卷:实现数据的持久化保存

docker pull mysql:5.7

docker run -d -p 3310:3306 -v /home/wangxun/mysql_5_7/conf:/etc/mysql/conf.d -v /home/wangxun/mysql_5_7/data:/var/lib/mysql
-e MYSQL_ROOT_PASSWORD=123456 --name=mysql_5_7_test mysql:5.7 #挂载出配置文件,数据文件,并设置mysql的密码

数据卷挂载技术的核心思想

1. 哪怕容器退出了或者容器停止运行了,数据的双向同步仍然存在
2. 哪怕容器被删除了,已经同步到主机的数据仍然存在
3. 只要在本地修改,不必直接进入容器,本质上也实现了数据的备份

docker数据卷手动挂载的3种方式

  1. 匿名挂载
#匿名挂载

-v 容器内路径

docker run -P --name=nginx_test -v /etc/nginx nginx

docker volume ls  #查看所有volume的情况

此时发现:

local               nvninfivnfinviofvofovojd03040r3249i-03g
  1. 具名挂载
#具名挂载

docker run -P --name=nginx_test2 -v juming-nginx:/etc/nginx nginx  #这个juming-nginx不是一个路径,只是为挂载卷起了一个名字

docker volume ls  #查看所有volume情况

此时发现:

local               juming-nginx
  1. 写明对应路径的挂载方式
-v 主机目录:容器目录  #核心参数

查找挂载卷的位置

1. docker volume inspect juming-nginx  #查看该名字对应的卷的原生数据,其中包含挂载卷的位置信息
2. docker inspect 容器id #在容器的挂载信息里找到挂载卷的位置

注意:要区别三种卷的挂载方式

  1. 匿名挂载
  2. 具名挂载
  3. 写明对应路径的挂载方式

拓展

ro readonly  #只读
rw readwrite #可读可写 #一旦设置了容器的权限,容器对我们挂载出来的内容就有了权限限定 docker run -d -P --name=nginx_test -v juming-nginx:/etc/nginx:ro nginx #只能通过宿主机操作,容器内部无法操作
docker run -d -P --name=nginx_test -v juming-nginx:/etc/nginx:rw nginx

初识Dockerfile:脚本方式挂载

dockerfile: 构建docker镜像的构建文件,是一个命令脚本

简单尝试写一个dockerfile文件

  1. cd /home/wangxun/docker_volume_test
  2. vim dockerfile01
脚本内容(按层创建自定义的镜像):

FROM centos  #创建的镜像的基础

VOLUME ["volume01", "volume02"]  #指定镜像的挂载卷

CMD echo "---this is the end---"  #输出指定的消息

CMD /bin/bash  #设置交互sehll类型
  1. 使用dockerfile文件脚本
docker build -f /home/wangxun/docker_volume_test/dockerfile1 -t wangxun/centos:1.0 .

#脚本路径  生成的镜像名+版本   最后的一个.不要漏掉
  1. 使用自己创建的镜像
docker images

docker run -it --name=my_centos wangxun/centos:1.0 /bin/bash  #会看到自己挂载的卷

docker inspect 容器id  #找到卷挂载信息

#根据卷挂载信息里的挂载卷信息找到挂载卷位置

part2数据卷容器:

数据卷容器

实现容器之间的数据共享:让某个容器(父容器)为其他容器(子容器)提供数据

docker02 --volumes-from docker01  #--volumes-from 为核心参数

享受备份机制,不是随意的可以删除掉的

只要某个容器还在使用数据,哪怕父容器被删除了,子容器中的数据还在,表现为继承,实际上互为备份

与简单意义上的数据共享又有本质区别:

数据卷容器技术,本质是一种数据备份技术,必须该卷涉及到的所有容器都删除(如果挂载到了宿主机,宿主机内挂载

卷也要删除),该数据卷才真正意义上的被删除

数据卷容器的练习: 实现多个mysql共享一个数据库

docker pull mysql:5.7

docker run -d -p 3310:3306 -v /home/wangxun/mysql_5_7/conf:/etc/mysql/conf.d -v /home/wangxun/mysql_5_7/data:/var/lib/mysql
-e MYSQL_ROOT_PASSWORD=123456 --name=mysql01 mysql:5.7 #挂载出配置文件,数据文件,并设置mysql的密码 docker run -d -p 3311:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql02 --volumes-from mysql01 mysql:5.7 #正常启动一个容器,只不过该容器要继承于某个父容器(表面上的继承,实际上互为数据数据备份)

不是随意的可以享受到这种备份机制的

  1. 容器挂载到宿主机: -v

​ 容器之间相互挂载: --volumes-from

只有挂载的卷可以享受互为备份和数据共享的机制

  1. 其实:

​ 宿主机也是一个容器,只不过是一个最顶级的容器

换而言之: 容器间共享数据,删除父容器,子容器与最顶级的宿主机之间仍然遵循数据卷互为备份的机制

  1. 时刻牢记:

docker卷技术始终是围绕挂载卷来说的,非卷数据并不在研究范围

最新文章

  1. Windows Server 2008 R2 域控服务器运行nslookup命令默认服务器显示 UnKnown
  2. 用Excel创建SQL server性能报告
  3. C++strng流(入门级)
  4. mysql 配置 utf8 依然乱码
  5. iOS : 静态库制作
  6. MDI端口和MDIX端口是什么? 又有什么作用?
  7. jQuery scroll(滚动)延迟加载
  8. 关于css3的calc()
  9. 关于ios::sync_with_stdio(false)
  10. ssh框架实现员工部门增删改查源码
  11. 15_Python模块化编程_Python编程之路
  12. springboot 2.0部署到Tomat8.5上
  13. SpringBoot-简单实例
  14. Java学习笔记之linux配置java环境变量(三种环境变量)
  15. centos 7下安装mysql
  16. 课程一(Neural Networks and Deep Learning),第二周(Basics of Neural Network programming)—— 0、学习目标
  17. SQL语句:Mac 下 处理myql 不能远程登录和本地登录问题
  18. Shell脚本的学习(一)
  19. 针对IE及其它的css hack
  20. 最小生成树-Borůvka算法

热门文章

  1. c++:-3
  2. Azure DevOps (十二) 通过Azure Devops部署一个SpringBoot应用
  3. go 语言开发1 环境配置和语言基础
  4. CMake技术总结
  5. 项目:Six Sigma
  6. 一条更新SQL的内部执行及日志模块
  7. Seata源码分析(一). AT模式底层实现
  8. C++:数的变化
  9. LVS+keepalived高可用
  10. 2021.03.20【NOIP提高B组】模拟 总结