Dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本。html
(1)docker从基础镜像运行一个容器
(2)执行一条指令并对容器做出修改
(3)执行相似docker commit的操做提交一个新的镜像层
(4)docker再基于刚提交的镜像运行一个新容器
(5)执行dockerfile中的下一条指令直到全部指令都执行完成java
从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别表明软件的三个不一样阶段,linux
Dockerfile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可,协力充当Docker体系的基石。
git
好比:WORKDIR $MY_PATHgithub
ENTRYPOINT :
3. 指定一个容器启动时要运行的命令
4. ENTRYPOINT 的目的和 CMD 同样,都是在指定容器启动程序及参数web
Docker Hub 中 99% 的镜像都是经过在 base 镜像中安装和配置须要的软件构建出来的
docker
自定义mycentos目的使咱们本身的镜像具有以下: 登录后的默认路径 vim编辑器 查看网络配置ifconfig支持
准备编写DockerFile文件
我这里就在根目录下的mydocker文件夹下新建一个Dockerfile2文件
apache
myCentOS内容DockerFile
Dockerfile2文件写入的内容,邮箱改为本身的,ENV用于设置环境变量,WORKDIR就是登陆的默认路径,echo是构建成功输出打印的内容。vim
FROM centos MAINTAINER xdr630<xdr630@126.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--------------ok" CMD /bin/bash
docker build -t 新镜像名字:TAG .
会看到 docker build 命令最后有一个 . “. ”表示当前目录
centos
docker build -f /mydocker/Dockerfile2 -t mycentos:1.3 .
docker images 查看下:
docker run -it 新镜像名字:TAG
能够看到,咱们本身的新镜像已经支持vim/ifconfig命令,扩展成功了。
默认登陆的路径改变了,也可使用vim了和ifconfig命令了
docker history 镜像名
docker images 镜像名,这样也能够模糊查询不一样版本的mycentos
docker run -it -p 8888:8080 tomcat ls -l
上面的 ls -l 就会把CMD前面的一行给覆盖掉,至关于执行了 ls -l /usr/local/tomcat
这个时候tomcat也没有启动:
curl命令能够用来执行下载、发送各类HTTP请求,指定HTTP头部等操做。
若是系统没有curl可使用yum install curl安装,也能够下载安装。
curl是将下载文件输出到stdout
使用命令:curl http://www.baidu.com
执行后,www.baidu.com的html就会显示在屏幕上了
FROM centos RUN yum install -y curl CMD [ "curl", "-s", "http://ip.cn" ]
这是最简单的使用方法。用这个命令得到了http://curl.haxx.se指向的页面,一样,若是这里的URL指向的是一个文件或者一幅图均可以直接下载到本地。若是下载的是HTML文档,那么缺省的将只显示文件头部,即HTML文档的header。要所有显示,请加参数 -i
咱们能够看到可执行文件找不到的报错,executable file not found。
以前咱们说过,跟在镜像名后面的是 command,运行时会替换 CMD 的默认值。
所以这里的 -i 替换了原来的 CMD,而不是添加在原来的 curl -s http://ip.cn 后面。而 -i 根本不是命令,因此天然找不到。
那么若是咱们但愿加入 -i 这参数,咱们就必须从新完整的输入这个命令:
$ docker run myip curl -s http://ip.cn -i
FROM centos RUN yum install -y curl ENTRYPOINT [ "curl", "-s", "http://ip.cn" ]
FROM centos MAINTAINER zzyy<zzyybs@126.com> #把宿主机当前上下文的c.txt拷贝到容器/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:$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/logs/catalina.out
docker run -d -p 9080:8080 --name myt9 -v /zzyyuse/mydockerfile/tomcat9/test:/usr/local/apache-tomcat-9.0.8/webapps/test -v /zzyyuse/mydockerfile/tomcat9/tomcat9logs/:/usr/local/apache-tomcat-9.0.8/logs --privileged=true zzyytomcat9
备注
Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied
解决办法:在挂载目录后多加一个--privileged=true参数便可
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>test</display-name> </web-app>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> -----------welcome------------ <%="i am in docker tomcat self "%> <br> <br> <% System.out.println("=============docker tomcat self");%> </body> </html>