概述
Docker File是一个由一系列命令组成的脚本文件,该脚本文件用来构建镜像文件,比如官方的tomcat、ngnix都是通过dockerfile构建的镜像
流程:开发应用=>DockerFile=>打包为镜像=>上传到仓库(私有仓库,公有仓库)=> 下载镜像 => 启动 运行。
步骤
1、基础语法
- 每条保留字指令都必须为大写字母且后面要跟随至少一个参数
- 指令按照从上到下,顺序执行
- # 表示注释
- 每条指令都会创建一个新的镜像层,并对镜像进行提交
- 编写DockerFile文件 建议文件名dockerfile
2、流程
- docker从基础镜像运行一个容器
- 执行一条指令并对容器做出修改
- 执行类似 docker commit 的操作提交一个新的镜像层
- Docker再基于刚提交的镜像运行一个新容器
- 执行dockerfile中的下一条指令直到所有指令都执行完成!
3、说明
从应用软件的角度来看,DockerFile,docker镜像与docker容器分别代表软件的三个不同阶段。 DockerFile 是软件的原材料 (代码) Docker 镜像则是软件的交付品 (.apk)
Docker 容器则是软件的运行状态 (客户下载安装执行)
DockerFile 面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可
DockerFile:需要定义一个DockerFile,DockerFile定义了进程需要的一切东西。DockerFile涉及的内容 包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进 程和内核进程(当引用进行需要和系统服务和内核进程打交道,这时需要考虑如何设计 namespace的权 限控制)等等。
Docker镜像:在DockerFile 定义了一个文件之后,Docker build 时会产生一个Docker镜像,当运行 Docker 镜像时,会真正开始提供服务;
Docker容器:容器是直接提供服务的。
4、关键字
FROM # 基础镜像,当前新镜像是基于哪个镜像的 MAINTAINER # 镜像维护者的姓名混合邮箱地址 RUN # 容器构建时需要运行的命令 EXPOSE # 当前容器对外保留出的端口 WORKDIR # 指定在创建容器后,终端默认登录的进来工作目录,一个落脚点 ENV # 用来在构建镜像过程中设置环境变量 ADD # 将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包 COPY # 类似ADD,拷贝文件和目录到镜像中! VOLUME # 容器数据卷,用于数据保存和持久化工作 CMD # 指定一个容器启动时要运行的命令,dockerFile中可以有多个CMD指令,但只有最 后一个生效! ENTRYPOINT # 指定一个容器启动时要运行的命令!和CMD一样 ONBUILD # 当构建一个被继承的DockerFile时运行命令,父镜像在被子镜像继承后,父镜像的 ONBUILD被触发
实战
Docker Hub 中99% 的镜像都是通过在base镜像(Scratch)中安装和配置需要的软件构建出来的
制作centos镜像
查看官方的centos
[root@izj6c22bffydfp7tlrbx7fz ~]# docker run -it centos [root@f9bb0cbe11d1 /]# pwd / [root@f9bb0cbe11d1 /]# vim test.txt bash: vim: command not found [root@f9bb0cbe11d1 /]# ifconfig bash: ifconfig: command not found [root@f9bb0cbe11d1 /]#
不支持vim 、ifconfig等,自己制作一个支持vim和ifconfig的centos
编写dockerfile文件
mkdir docker_centos vim dockerfile_centos FROM centos MAINTAINER lph<123@qq.com> ENV MYPATH /usr/local WORKDIR $MYPATH RUN yum -y install vim RUN yum -y install net-tools EXPOSE 80 CMD echo $MYPATH CMD echo "----------end--------" CMD /bin/bash
构建
#docker build -f dockerfile地址 -t 新镜像名字:TAG . # . 表示当前目录 docker build -f dockerfile_centos -t mycentos:1.0 .
运行
docker run -it 新镜像名字:TAG
测试vim 和ifconfig
列出镜像地的变更历史
docker history 镜像名
注
CMD 和 ENTRYPOINT 的区别 两个命令都是指定一个容器启动时要运行的命令 CMD:Dockerfile 中可以有多个CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数 替换! ENTRYPOINT: docker run 之后的参数会被当做参数传递给 ENTRYPOINT,之后形成新的命令组合! 测试CMD : # 1、构建dockerfil vim dockerfile-cmd-test FROM centos CMD [ "ls", "-a" ] 2、build 镜像 docker build -f dockerfile-cmd-test -t cmdtest . 3、执行 docker run 554bc6952657 会列出目录 etc home lib lib64 如果我们希望用 -l 列表展示信息,我们就需要加上 -l参数 docker run cmdtest -l 但是运行报错,就是因为 -l 替换了原来的 CMD,而不是添加在原来的 ls -a 后面。而 -l 根本不是命令,所 以自然找不到。 测试ENTRYPOINT命令 vim dockerfile-entrypoint-test FROM centos ENTRYPOINT [ "ls", "-a" ] docker build -f dockerfile-entrypoint-test -t entrypointtest . docker run ae07199f9144 bin dev etc home lib lib64 测试-l参数,发现可以直接使用,这里就是一种追加,我们可以明显的知道 CMD 和ENTRYPOINT 的区别了 docker run entrypointtest -l
自定义tomcat镜像
编写dockerfile
# vim Dockerfile FROM centos MAINTAINER lph<123@qq.com> #把宿主机当前上下文的read.txt拷贝到容器/usr/local/路径下 COPY read.txt /usr/local/cincontainer.txt #把java与tomcat添加到容器中 ADD jdk-8u11-linux-x64.tar.gz /usr/local/ ADD apache-tomcat-9.0.22.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_11 ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.22 ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.22 ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin #容器运行时监听的端口 EXPOSE 8080 #启动时运行tomcat # ENTRYPOINT ["/usr/local/apache-tomcat-9.0.22/bin/startup.sh" ] # CMD ["/usr/local/apache-tomcat-9.0.22/bin/catalina.sh","run"] CMD /usr/local/apache-tomcat-9.0.22/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.22/bin/logs/catalina.out
构建镜像
#文件名是Dockerfile 不用写-f docker build -t diytomcat .
备注:Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied 解决办法:在挂载目录后多加一个--privileged=true参数即可
启动
docker run -d -p 9090:8080 --name mydiytomcat -v /home/kuangshen/build/tomcat/test:/usr/local/apache-tomcat9.0.22/webapps/test -v /home/kuangshen/build/tomcat/tomcat9logs/:/usr/local/apache-tomcat9.0.22/logs --privileged=true diytomcat
验证测试访问! curl localhost:9090
结合前面学习的容器卷将测试的web服务test发布
发布镜像
注册dockerhub Docker Hub,需要有一个账号
# 1、查看登录命令 [root@lph tomcat]# docker login --help Usage: docker login [OPTIONS] [SERVER] # 2、登录 [root@lph tomcat]# docker login -u lph Password: WARNING! Your password will be stored unencrypted in /root/.docker/config.json. Configure a credential helper to remove this warning. See https://docs.docker.com/engine/reference/commandline/login/#credentialsstore Login Succeeded # 3、将镜像发布出去 [root@lph tomcat]# docker push lph/diytomcat:1.0 The push refers to repository [docker.io/library/diytomcat] 0f02399c6fdf: Preparing e79ea0c3a34e: Preparing 09281fa8fe38: Preparing b56a902b0aef: Preparing 0683de282177: Preparing # 拒绝:请求的资源访问被拒绝 denied: requested access to the resource is denied # 问题:本地镜像名无帐号信息,解决加 tag即可 docker tag 251ca4419332 lph/diytomcat:1.0 # 再次 push, ok [root@lph tomcat]# docker push lph/diytomcat:1.0 The push refers to repository [docker.io/lph/diytomcat] 0f02399c6fdf: Pushing [========> ] 9.729MB/59.76MB e79ea0c3a34e: Pushing [==========> ] 3.188MB/15.41MB 09281fa8fe38: Pushing [> ] 3.823MB/324MB b56a902b0aef: Pushed 0683de282177: Pushing [=> ] 5.997MB/237.1MB
阿里云镜像服务
1、登录阿里云 2、找到容器镜像服务
3、创建命名空间
4、创建镜像仓库
5、点击进入这个镜像仓库,可以看到所有的信息
6、测试推送发布
# 1、登录阿里云 [root@lph tomcat]# docker login --username=18225148644 registry.cnbeijing.aliyuncs.com Password: WARNING! Your password will be stored unencrypted in /root/.docker/config.json. Configure a credential helper to remove this warning. See https://docs.docker.com/engine/reference/commandline/login/#credentialsstore Login Succeeded # 2、设置 tag docker tag [ImageId] registry.cn-beijing.aliyuncs.com/bilibilikuangshen/lph-test:[镜像版本号] [root@lph tomcat]# docker tag 251ca4419332 registry.cnbeijing.aliyuncs.com/bilibili-kuangshen/lph-test:v1.0 # 3、推送命令 docker push registry.cn-beijing.aliyuncs.com/bilibili-lph/lphtest:[镜像版本号] [root@lph tomcat]# docker push registry.cnbeijing.aliyuncs.com/bilibili-lph/lph-test:v1.0
在阿里云镜像仓库查看效果!