Docker数据卷

目录

一、如何管理docker容器中的数据?

二、数据卷

1、数据卷原理

2、数据卷作用

3、数据卷案例

 三、数据卷容器

1、数据卷容器作用

2、数据卷容器案例

四、容器互联(使用centos镜像)

五、总结


管理 Docker容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers ) 。

一、如何管理docker容器中的数据?

二、数据卷


1、数据卷原理

将容器内部的配置文件目录,挂载到宿主机指定目录下

    数据卷默认会一直存在,即使容器被删除
    宿主机和容器是两个不同的名称空间,如果想进行连接需要使用ssh,exec和attch也类似于ssh这种方式登录
    在企业中ssh这种登录方式会比较危险,安全漏洞很大,尽量减少ssh这种,杜绝了频繁使用exec
    因此使用数据卷的凡是把容器内部的文件挂载到宿主机指定目录下进行修改,当容器里的文件频繁需要更改时不需要登录进行,直接使用数据卷方式在宿主机指定的目录下进行修改即可。方便又安全

2、数据卷作用

数据卷是一个共容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行地mount操作

3、数据卷案例

实例:将宿主机目录/var/www分别挂载到c1、c2容器中地/data1,/data2

创建两个容器,指定挂载点,并在宿主目录写入数据

docker run -itd -v /var/www:/data1 --name c1 centos:7 bash
docker run -itd -v /var/www:/data2 --name c2 centos:7 bash
 
#在宿主机目录写入数据
echo "123456" >1.txt

 

 在C2容器上创建一个文件,宿主机和C1上也能看到

 

 三、数据卷容器

1、数据卷容器作用

让两个容器实现数据共享

如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。

php ---->mysql之间想要通讯,通过socket

2、数据卷容器案例

需求:创建数据卷容器

#创建一个容器作为数据卷容器
docker run -it --name test1 -v /data1 -v /data2 centos:7 bash    #创建并进入容器
echo "this is test02 file" > /data1/test.txt              #容器内创建测试文件1
echo "THIS IS TEST2 FILE" > /data2/TEST.txt                    #容器内创建测试文件2
 
#使用--volumes-from来挂载test2容器中的数据卷到新的容器
docker run -it --name test2 --volumes-from test1 centos:7 bash    #创建并进入容器
cat data1/test.txt                                            #查看测试数据是否同步
cat data2/TEST.txt

四、容器互联(使用centos镜像)

 容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。

五、总结

本文介绍了通过数据卷和数据卷容器对容器内数据进行共享、备份和恢复等操作,通过这些机制,即使容器在运行中出现故障,用户也不必担心数据发生丢失,只需要快速地重新创建容器即可。在生成容器的同时,加上-v选项,指定把当前服务器的目录映射到容器中。

六、Dockerfile

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

cd /home/javazsx/software
mkdir mydocker
vi mycentosDockerfile

向 mycentosDockerfile 编辑内容

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

构建镜像

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

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

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

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

cd /home/zsx/software
mkdir mydocker
vi mytomcatDockerfile

向 mytomcatDockerfile 编辑内容

FROM centos:7
MAINTAINER zsx "ycs020715@163.com"

ENV workerDir /home/zsx/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/zsx/dockerfile/3/apache-tomcat-8.5.20/bin/catalina.sh","run"]

 构建镜像

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

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

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

 浏览器输入

http://192.168.195.139:49153/
http://192.168.195.139:49154/

都可以访问到tomcat

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值