数据卷(Data Volumes)简单介绍Dockerfile
创始人
2024-03-22 04:22:55
0

目录

前言

一、宿主机与容器之间的文件拷贝

二、数据卷

三、数据卷容器

四、Dockerfile

1、Dockerfile简介

2、制作镜像 


前言

Docker 数据管理

   在生产环境中使用 Docker ,往往需要对数据进行持久化,或者需要在多个容器之间进行

   数据共享,这必然涉及容器的数据管理操作

容器中的管理数据主要有两种方式:

   数据卷 Data Volumes 容器内数据直接映射到本地主机环境;

   数据卷容器(Data Volume Containers 使用特定容器维护数据卷

当然还有最原始的copy方式,这个也是管理数据的方式,但是基本不会用到

一、宿主机与容器之间的文件拷贝

引言:利用MySQL镜像安装MySQL服务

docker run -p 3307:3306 --name mysql1   -di -v /home/cxy/data/mysql/mysql.conf.d/:/etc/mysql/mysql.conf.d/ -v /home/cxy/data/mysql/data/:/var/lib/mysql -v

/home/cxy/data/mysql/log/:/var/log -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

从容器中拷贝文件到宿主机

docker cp tomcat1:/usr/local/tomcat/webapps/hello /cxy/software/apache-tomcat-8.5.20/webapps

从宿主机拷贝文件到容器

docker cp /cxy/software/apache-tomcat-8.5.20/webapps tomcat1:/usr/local/tomcat/

二、数据卷

数据卷(Data Volumes)

   数据卷是一个可供一个或多个容器使用的特殊目录,它将主机操作系统目录直接映射进容器

 它可以提供很多有用的特性:

   1.数据卷 可以在容器之间共享和重用

   2.对数据卷的修改会立马生效

   3.对数据卷的更新,不会影响镜像

   4.数据卷 默认会一直存在,即使容器被删除

  :数据卷 是被设计用来持久化数据的,它的生命周期独立于容器,Docker不会在容器被删除后自动删除数据卷,并且也不存在垃圾回收这样的机制来处理没有任何容器引用的数据卷,无主的数据卷可能会占据很多空间, 所以要及时删除

   ## 挂载数据卷,最好是通过run而非create/start创建启动容器

   ## create/start命令创建启动容器后,再挂载数据卷相当麻烦,要修改很多配置文件,但并非不可以

将宿主机的目录与容器的目录进行挂载,实现数据共享

docker run -di --name c2 -v /home/cxy/data/:/home/cxy/data/ centos:7

结论:不管宿主机、容器在指定目录创建文件夹还是文件,都会会被共享;  

三、数据卷容器

数据卷容器

   如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。

   数据卷容器也是一个容器,但是它的目的是专门提供数据卷给其他容器挂载

docker run -di -v /home/cxy/data/c4 --name c4 centos:7
docker run -di --volumes-from c4 --name c6 centos:7 

注:-v 后面接的共享数据真实存放路径 

其中c4为数据卷容器,c6为普通容器,其中c4就起到一个桥接作用,我们可以通过docker inspect查看容器的详细情况  

docker inspect c4
docker inspect c6

结论:不管c4、c6在指定目录创建文件夹还是文件,都会会被共享;  

四、Dockerfile

1、Dockerfile简介

dockerfile 是一个文本格式的配置文件, 用户可以使用 Dockerfile 来快速创建自定义的镜像,

   另外,使用Dockerfile去构建镜像好比使用pom去构建maven项目一样,有异曲同工之妙

dockerfile基本结构

   Dockerfile 由一行行命令语句组成, 并且支持以#开头的注释行,一般而言, Dockerfile 主体内容分为四部分:

   基础镜像信息、 维护者信息、 镜像操作指令和容器启动时执行指令。

      部分                         命令

基础镜像信息              FROM

维护者信息                  MAINTAINER

镜像操作指令             RUN、(COPY/ADD)、EXPOSE、WORKDIR、ONBUILD、USER、                                      VOLUME等

容器启动时执行指令    CMD、ENTRYPOINT

2、制作镜像 

自定义centos,具备vim及ifconfig作用(体会学习Dockerfile的意义)

cd /cxy/software
mkdir mydocker
vi mycentosDockerfile

 向 mycentosDockerfile 编辑内容

FROM centos:7
MAINTAINER cxy "cxy@qq.com"
RUN yum -y install vim
RUN yum install net-tools.x86_64 -y
CMD /bin/bash

构建镜像  

docker build -f mycentosDockerfile -t cxy/centos:v1.0 .

 通过镜像运行一个容器进行测试

docker run -it --name mc1 cxy/centos:v1.0 /bin/bash

 自定义tomcat8(熟悉几乎所有的Dockerfile命令)

cd /cxy/software
mkdir mydocker
vi mytomcatDockerfile

向 mytomcatDockerfile 编辑内容  

FROM centos:7 (指定基础镜像,并且必须是第一条指令)
MAINTAINER cxy"cxy@qq.com" (
指明该镜像的作者和其电子邮件)

ENV workerDir /home/cxy/dockerfile/3
WORKDIR $workerDir  (工作区间)

ADD jdk-8u151-linux-x64.tar.gz $workerDir       (复制命令并解压)
COPY apache-tomcat-8.5.20.tar.gz $workerDir(
复制命令
RUN tar -xvf apache-tomcat-8.5.20.tar.gz apache-tomcat-8.5.20

ENV JAVA_HOME $workerDir/jdk1.8.0_151       (配置环境变量)
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar  (
配置环境变量)
ENV TOMCAT_HOME $workerDir/apache-tomcat-8.5.20  (
配置环境变量)
ENV PATH $JAVA_HOME/bin:$TOMCAT_HOME/bin:$TOMCAT_HOME/lib:$PATH

EXPOSE 8080
ENTRYPOINT ["/home/cxy/dockerfile/3/apache-tomcat-8.5.20/bin/catalina.sh","run"]

构建镜像

 docker build -f mytomcatDockerfile -t cxy/tomcat8:v1.0 .

 通过镜像运行2个容器进行测试

docker run -di --name mt1 -P cxy/tomcat8:v1.0
docker run -di --name mt2 -P cxy/tomcat8:v1.0

最后浏览器输入地址即可访问 

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...