dockerfile
步骤
-
手动编写一个dockerfile文件,当然要符合file的规范 -
有这个问文件后,直接docker builder命令执行,获得一个自定义的镜像 -
docker run ##是什么
dockerfile是用来构建dokcer镜像的构建文件,是由一系列命令和参数构成的脚本。
一个简单的dokcerfile:
ROME centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,--------success1"
CMD /bin/bash
dockerfile解析过程
基本知识
1.每条保留字指令都必须大写字母且字母后面要跟随至少一个参数
2.指令按照从上到下,顺序执行
3.#表示注释
4.每条指定都会创建一个新的镜像层,并对镜像进行提交
dokcerfile从基础镜像运行一个容器
1.docker从基础镜像运行一个容器
2.执行一条指令并对容器做出修改
3.执行类似dokcer commit的操作提交一个新的镜像层
4.docker再基于刚才提交的镜像运行一个新容器
5.执行dokcerfile中的下一条指令直到所有指令都执行完成
dokcerfile体系结构(保留字指令)
1. FROM //基础镜像,当前新镜像是基于哪个镜像的
2. MAINTAINER //镜像维护者的姓名和邮箱地址
3. RUN //容器构建时需要运行的命令
4. EXPOSE //当前容器对外暴露的端口号
5. WORKDIR //指定在容器创建后,终端默认登录的进来工作目录,一个落脚点
6. ENV //用来在构建镜像过程中设置环境变量
7. ADD //将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包
8. COPY //类似ADD,拷贝文件和目录到镜像中。
将从构建上下文目录中<源路径>的文件/目录复制到新的一层的镜像内的<目标路径>位置
COPY src dest 或者 COPY ["src","dest"]
9. VOLUME //容器数据卷,用于数据保存和持久化工作
10. CMD //指定一个容器启动时要运行的命令
dockerfile中可以有多个CMD指令,但只有最后一个生效,CMD会被docker run 之后的参数替换掉
11.ENTRYPOINT//指定一个容器启动时要运行的命令
ENTRYPOINT的目的和CMD一样,都是在指定容器启动程序及参数
12. ONBUILD //触发器,当构建一个被继承的dockerfile时运行命令父镜像在被子继承后父镜像的onbuild被触发
ENV MY_PATH/usr/mytest
这个环境变量可以在后续的任何RUN指令中使用,这就如同命令前面指定了环境变量前缀一样;
也可以在其他指令中直接使用这些环境变量。
比如: WORKDIR $MY_PATH
CMD指令的格式和RUM相似,也是两种格式
shell格式:CMD<命令>
exec格式:CMD["可执行文件","参数1","参数2"...]
参数列表格式:CMD["参数1","参数2"...],在指定了ENTRYPOINT 指令后,用CMD指定具体的参数
案例
案例一:自定义mycentos,具备以下功能
1.登录后的默认路径
2.vim编辑器
3.查看网络配置ifconfig支持
FROM centos
MAINTAINER anhuiwuyanzhu<anhuiwuyanzhu@gmail.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 "success------------------0k"
CMD /bin/bash
构建镜像
docker build -f /Volumes/project/mydocker/Dockerfile2 -t anhuiwuyanzhucentos:1.3 .
案例二:自定义制作CMD版可以查询IP信息的容器
FROM centos
RUN yum install -y curl
CMD ["curl","-s","http://ip.cn"]
构建镜像
docker build -f /Volumes/project/mydocker/Dockerfile3 -t myip .
如果我们需要http头响应信息,我们需要加上参数 -i
docker run -it myip -i
这个时候cmd就不好使了,-i命令就会把原本的功能给替换掉
使用ENTRYPOINT可以很好的解决这个问题
FROM centos
RUN yum install -y curl
ENTRYPOINT ["curl","-s","http://ip.cn"]
构建镜像:
docker build -f /Volumes/project/mydocker/Dockerfile4 -t myip2 .
案例三:ONBUILD
父dockerfile
Dockerfile4
FROM centos
RUN yum install -y curl
CMD ["curl","-s","http://ip.cn"]
ONBUILD RUN echo "father image onbuild--------------------886"
子dokcerfile
dockerfile5
FROM dockerfile4
当构建dokcerfile5时,会执行onbuild里的事件,即打印出
father image onbuild--------------------886
案例tomcat
FROM centos
MAINTAINER anhuiwuyanzhu<anhuiwuyanzhu@gmail.com>
#把宿主机当前上下文的c.txtK拷贝到容器/usr/local/路径下
COPY c.txt /usr/local/cincontainer.txt
#把java与tomcat添加到容器中
ADD jdk-8u171-linux-x64.tar.gz /usr/local/
ADD apache-tomcat-9.0.8.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_171
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.8
ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.8
ENV PATH $PATH:$PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:CATALINA_HOME/bin
#容器运行时监听的端口
EXPOSE 8080
#启东时运行tomcat
#ENTRYPOINT ["/usr/local/apache-tomcat-9.0.8/bin/startup.sh"]
#CMD ["/usr/local/apache-tomcat-9.0.8/bin/catalina.sh","run"]
CMD /usr/local/apache-tomcat-9.0.8/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.8/bin/log/catalina.out
dokcer build后,要run,run的时候记得挂载容器数据卷,要不然tomcat启动了不能加载宿主机数据,那就没有意义了。
dokcer run -d -p 80:8080 --name mytomcat
-v /.....:/usr/local/apache-tomcat-9.0.8/webapps/test
-v /.....:/usr/local/apache-tomcat-9.0.8/logs
--privileged=true
tomcat9
–privileged=true是为了防止写权限不够
tomcat9是唯一容器名,或者写成容器ID也行
CMD /usr/local/apache-tomcat-9.0.8/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.8/bin/log/catalina.out
|