Docker宿主机与容器之间的文件拷贝实例详解
一,Docker运行MySQL容器
容器中的管理数据主要有两种方式:
数据卷 Data Volumes 容器内数据直接映射到本地主机环境;
数据卷容器(Data Volume Containers 使用特定容器维护数据卷
利用MySQL镜像安装MySQL服务
docker run -p 3307:3306 --name mysql1 -di -v /home/javaxl/data/mysql/mysql.conf.d/:/etc/mysql/mysql.conf.d/ -v /home/javaxl/data/mysql/data/:/var/lib/mysql -v /home/javaxl/data/mysql/log/:/var/log -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
在虚拟机连接工具中创建MySQL数据库,将以上代码在链接工具运行即可
执行完毕后在数据库中尝试链接
当出现以下错误时也许是冲突的原因,有两个后多个密码相同的数据库,在链接工具中停掉其中一个即可(命令如下:docker stop 数据库名)
从容器中拷贝文件到宿主机
docker cp tomcat1:/usr/local/tomcat/webapps/hello /javadxy/software/apache-tomcat-8.5.20/webapps
从宿主机拷贝文件到容器(与上反过来)
docker cp /javadxy/software/apache-tomcat-8.5.20/webapps tomcat1:/usr/local/tomcat/
二,数据卷
数据卷是一个可供一个或多个容器使用的特殊目录,它将主机操作系统目录直接映射进容器。
它可以提供很多有用的特性:
1.数据卷 可以在容器之间共享和重用
2.对数据卷的修改会立马生效
3.对数据卷的更新,不会影响镜像
4.数据卷 默认会一直存在,即使容器被删除
将宿主机的目录与容器的目录进行挂载,实现数据共享
docker run -di --name c2 -v /home/dxy/data/:/home/xionger/data/ centos:7
前面放的是前面是宿主机目录,后面是容器目录
执行以上命令
结论:不管宿主机、容器在指定目录创建文件夹还是文件,都会会被共享;
三,数据卷容器
数据卷容器
如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。
数据卷容器也是一个容器,但是它的目的是专门提供数据卷给其他容器挂载
docker run -di -v /home/javadxy/data/c4 --name c4 centos:7
标记部分属于内部容器
docker run -di --volumes-from c4 --name c6 centos:7
其中c4为数据卷容器,c6为普通容器,其中c4就起到一个桥接作用,我们可以通过docker inspect查看容器的详细情况
docker inspect c4
docker inspect c6(建议将这段copy出来后续会用的到)
会发现c4、c6目录挂载情况是一样的
结论:不管c4、c6在指定目录创建文件夹还是文件,都会会被共享;
四,Dockerfile制作增强版
自定义centos,具备vim及ifconfig作用(体会学习Dockerfile的意义)
cd /javaxl/software mkdir mydocker vi mycentosDockerfile
构建镜像
docker build -f mycentosDockerfile -t javadxy/centos:v1.0 .
通过镜像运行一个容器进行测试
docker run -it --name mc1 javadxy/centos:v1.0 /bin/bash
向 mycentosDockerfile 编辑内容
FROM centos:7 MAINTAINER javaxl "javaxl@qq.com" RUN yum -y install vim RUN yum install net-tools.x86_64 -y CMD /bin/bash
五,Docker制作自定义Tomcat
cd /javaxl/software mkdir mydocker vi mytomcatDockerfile -------------创建目录
向 mytomcatDockerfile 编辑内容
FROM centos:7
MAINTAINER javaxl "javaxl@qq.com"ENV workerDir /home/javaxl/dockerfile/3 ----------------代表容器自动跳转的容器
WORKDIR $workerDirADD 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.20ENV 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/javaxl/dockerfile/3/apache-tomcat-8.5.20/bin/catalina.sh","run"]ADD与COPY的区别:
add是将压缩包添加到工作目录并解压
copy只把压缩包上传至工作目录不解压
提示:将以上步骤完成之后不能直接执行以下命令,要看当前目录是否有jdk文件
以上没问题后在执行以下命令
docker build -f mytomcatDockerfile -t javaxl/tomcat8:v1.0 .
如图完成
通过镜像运行2个容器进行测试
docker run -di --name mt1 -P javaxl/tomcat8:v1.0 docker run -di --name mt2 -P javaxl/tomcat8:v1.0
然后在浏览器上输入地址访问Tomcat
http://192.168.195.139:49153/
http://192.168.195.139:49154/
总结
到此这篇关于Docker宿主机与容器之间的文件拷贝的文章就介绍到这了,更多相关Docker宿主机与容器的文件拷贝内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
docker-compose实现wireshark对linux主机进行抓包
这篇文章主要为大家介绍了docker-compose实现wireshark对linux主机进行抓包脚本示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-12-12docker容器间跨宿主机通信-基于overlay的实现方法
这篇文章主要介绍了docker容器间跨宿主机通信-基于overlay的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-02-02
最新评论