Docker容器数据卷

1.简介

1>Docker容器产生的数据,为了能保存数据在docker中我们使用卷。

2>作用:容器的持久化、容器间继承+共享数据

 

2.数据卷添加的几种方式:

1>直接命令添:docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名

docker run -it -v /mydataVolume:/dataVolumeContainer centos /bin/bash

#查看数据卷是否挂载成功(看Volumes(对应的目录结构),VolumeRW(读写权限))
docker inspect 容器ID

#带权限的命令 只读(VolumeRW为false):容器只能读取  主机可以读/写
docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名

 

2.DockerFile添加(划重点)

Dockerfile中使用VOLUME指令来给镜像添加一个或多个数据卷

步骤:1.编写file文件 > 2.build(编译)文件 > 3.运行所产生的镜像

VOLUME["/dataVolumeContainer","/dataVolumeContainer2","/dataVolumeContainer3"]

#出于可移植和分享的考虑,用-v 主机目录:容器目录这种方法不能够直接在Dockerfile中实现。

1>编写file文件:在宿主机上创建一个dockerfile文件,内容如下

# volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,--------success1"
CMD /bin/bash

2.编译文件,产生新的镜像文件(-f表示绝对路径[可省略])(最后有一个小点)

docker build -f /mydocker/dockerfile -t langao/centos .

#/mydocker/dockerfile文件路径
#langao/centos镜像名称

3.运行产生的新镜像文件 得到新的容器实例

docker run -it 镜像id /bin/bash

4.查询容器和宿主机对应的文件存放地址(会产生一个默认的地址 Mounts标签下 )

docker inspect 容器id

小结:

Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied
解决办法:在挂载目录后多加一个--privileged=true参数即可

 

3.数据卷容器

命名的容器挂载数据卷,其它容器通过挂载这个(父容器)实现数据共享,挂载数据卷的容器,称之为数据卷容器

步骤一:启动一个父容器,别名为dec01

docker run -it --name dec01 langao/centos

步骤二:dec02/dec03继承自dec01

docker run -it --name dec02 --volumes-from dec01 langao/centos

docker run -it --name dec03 --volumes-from dec01 langao/centos

步骤三:对任意一个容器进行修改、删除 其他两个容器也会改变,此时三个容器都能共享了

小结:

结论:容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止

 

4.DockerFile解析

Dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本。就如上面我们创建的dockerfile一样

 

2>构建三步骤

1.编写Dockerfile文件

2.docker build

3.docker run

 

3>DockerFile构建过程解析

Dockerfile内容基础知识

1:每条保留字指令都必须为大写字母且后面要跟随至少一个参数
2:指令按照从上到下,顺序执行
3:#表示注释
4:每条指令都会创建一个新的镜像层,并对镜像进行提交

Docker执行Dockerfile的大致流程

(1)docker从基础镜像运行一个容器
(2)执行一条指令并对容器作出修改
(3)执行类似docker commit的操作提交一个新的镜像层
(4)docker再基于刚提交的镜像运行一个新容器
(5)执行dockerfile中的下一条指令直到所有指令都执行完成

小结:

从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段,
*  Dockerfile是软件的原材料
*  Docker镜像是软件的交付品
*  Docker容器则可以认为是软件的运行态。
Dockerfile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可,合力充当Docker体系的基石。

1 Dockerfile,需要定义一个Dockerfile,Dockerfile定义了进程需要的一切东西。Dockerfile涉及的内容包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进程和内核进程(当应用进程需要和系统服务和内核进程打交道,这时需要考虑如何设计namespace的权限控制)等等;
 
2 Docker镜像,在用Dockerfile定义一个文件之后,docker build时会产生一个Docker镜像,当运行 Docker镜像时,会真正开始提供服务;
 
3 Docker容器,容器是直接提供服务的。

 

4>DockerFile体系结构(保留字指令)

FROM :基础镜像,当前新镜像是基于哪个镜像的
MAINTAINER :镜像维护者的姓名和邮箱地址
RUN :容器构建时需要运行的命令
EXPOSE :当前容器对外暴露出的端口
WORKDIR :指定在创建容器后,终端默认登陆的进来工作目录,一个落脚点
ENV :用来在构建镜像过程中设置环境变量
ADD :将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包(带解压功能的copy)
COPY :类似ADD,拷贝文件和目录到镜像中。将从构建上下文目录中 <源路径> 的文件/目录复制到新的一层的镜像内的 <目标路径> 位置
VOLUME :容器数据卷,用于数据保存和持久化工作
CMD :指定一个容器启动时要运行的命令(Dockerfile 中可以有多个 CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数替换)
ENTRYPOINT  :指定一个容器启动时要运行的命令(ENTRYPOINT 的目的和 CMD 一样,都是在指定容器启动程序及参数)
ONBUILD :当构建一个被继承的Dockerfile时运行命令,父镜像在被子继承后父镜像的onbuild被触发

小结:

 

5.编写DockerFile文件

1>centos

#来源centos(scratch类似于java中Object,是祖先类)
FROM centos
#姓名和邮箱
MAINTAINER lanago_q<lanago@qq.com>
#定义一个变量
ENV MYPATH /usr/local
#进入容器后的落脚点
WORKDIR $MYPATH
#安装vim
RUN yum -y install vim
RUN yum -y install net-tools
#对外暴露的端口
EXPOSE 80
#启动容器后执行的命令(CMD会被覆盖、ENTRYPOINT是追加)
CMD echo $MYPATH
CMD echo "success--------------ok"
CMD /bin/bash


#编译(TAG是版本 默认最新latest)
docker build -f 文件地址 -t 新镜像名字:TAG .

#运行
docker run -it 新镜像名字:TAG 

2>tomcat

FROM         centos
MAINTAINER    langao_q<langao@qq.com>
#把宿主机当前上下文的c.txt拷贝到容器/usr/local/路径下
COPY c.txt /usr/local/cincontainer.txt
#把java与tomcat添加到容器中(此处都是当前路径下的文件)
ADD jdk-8u211-linux-x64.tar.gz /usr/local/
ADD apache-tomcat-8.5.40.tar.gz /usr/local/
#安装vim编辑器
RUN yum -y install vim
#设置工作访问时候的WORKDIR路径,登录落脚点
ENV MYPATH /usr/local
WORKDIR $MYPATH
#配置java与tomcat环境变量
ENV JAVA_HOME /usr/local/jdk1.8.0_211
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-8.5.40
ENV CATALINA_BASE /usr/local/apache-tomcat-8.5.40
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
#容器运行时监听的端口
EXPOSE  8080
#启动时运行tomcat
# ENTRYPOINT ["/usr/local/apache-tomcat-8.5.40/bin/startup.sh" ]
# CMD ["/usr/local/apache-tomcat-8.5.40/bin/catalina.sh","run"]
CMD /usr/local/apache-tomcat-8.5.40/bin/startup.sh && tail -F /usr/local/apache-tomcat-8.5.40/bin/logs/catalina.out


#编译
docker build -f 文件地址 -t 新镜像名字:TAG .

#运行
docker run -d -p 9080:8080 --name myt8.5 -v /mydocker/tomcat8.5/test:/usr/local/apache-tomcat-8.5.40/webapps/test -v /mydocker/tomcat8.5/tomcat8.5logs/:/usr/local/apache-tomcat-8.5.40/logs --privileged=true tomcat8.5

3>mysql

#从dockerHub上拉取mysql
docker pull mysql:5.6

#运行
docker run -p 3306:3306 --name mysql -v /mydocker/mysql/conf:/etc/mysql/conf.d -v /mydocker/mysql/logs:/logs -v /mydocker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6

4>redis

#从dockerHub上拉取mysql
docker pull redis:3.2

#运行
docker run -p 6379:6379 -v /mydocker/redis/data:/data -v /mydocker/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf  -d redis:3.2 redis-server /usr/local/etc/redis/redis.conf --appendonly yes

#在/mydocker/redis/conf/redis.conf目录下创建redis.conf文件(第一个redis.conf是目录)
#redis.conf的内容可以参照网上的配置

#连接
docker exec -it 运行着Rediis服务的容器ID redis-cli

#持久化
#持久化文件在/mydocker/redis/data/文件中

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值