Dockerfile

一、简介

Dockerfile是用来构建Docker镜像的文本文件,是由一条条构建镜像所需的指令和参数构成的脚本

二、Dockerfile的构建过程
  1. 每条关键字指令都必须为大写且后面至少需跟随一个参数
  2. 指令按照从上到下顺序执行
  3. #表示注释
  4. 每条指令都会创建一个新的镜像层并对镜像进行提交

大致流程:

  • docker从基础镜像运行一个容器
  • 执行一条指令并对容器做出修改
  • 执行类似docker commit的操作提交一个新的镜像层
  • docker再基于刚提交的镜像运行一个新容器
  • 执行dockerfile中的下一条指令直到所有指令都执行完成
    在这里插入图片描述
三、指令简介
  1. FROM

基础镜像,当前新镜像是基于哪个镜像,指定一个已经存在的镜像作为模板,第一条必须是FROM

FROM openjdk:8u212-jre
  1. MAINTAINER

镜像维护者的姓名和邮箱

MAINTAINER answer xxx@qq.com
  1. RUN

容器构建时需要的命令,由两种格式shell和exec,其是在docker build时执行

shell:

RUN yum -y install vim

exec:

RUN ["可执行文件",“参数1”,“参数2”]
例:
RUN ["./test.php","dev","offline"]等价于 RUN ./test.php dev offline
  1. EXPOSE

端口映射

EXPOSE 3306
  1. WORKDIR

指定在创建容器后,终端默认登录进来的工作目录,一个落脚点
在这里插入图片描述

  1. USER

指定该镜像以什么样的用户去执行,如果都不指定,默认是root

  1. ENV

在构建过程中设置环境变量

ENV MY_NAME="John Doe"
ENV MY_DOG=Rex\ The\ Dog
ENV MY_CAT=fluffy
  1. VOLUME

容器数据卷,用于数据保存和持久化工作,其后面的参数是容器内目录所在路径,而宿主机上的挂载目录是随机生成的,docker -v则可以指定挂载到宿主机的具体目录下

VOLUME /usr/local/oas/file/

$ docker run —name tengine-web -d -p 9527:80 -p 9000:9000 \
-v /usr/local/tengine/logs:/var/log/nginx \
-v /usr/local/tengine/conf.d:/etc/nginx/conf.d \
-v /usr/local/tengine/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /usr/local/tengine/html:/usr/share/nginx/html \
-v /usr/local/oas/file:/usr/local/oas/file nginx
#可使用inspect查看挂载情况
docker inspect 容器名
  1. ADD

将宿主机目录下的文件拷贝进镜像并且会自动处理URL和解压tar压缩包

#添加所有以“hom”开头的文件:
ADD hom* /mydir/
  1. COPY

类似ADD,拷贝文件和目录到镜像中;
将从构建上下文目录中<源路径>的文件和/目录复制到新的一层的镜像内<目标路径>位置

COPY hom* /mydir/
  1. CMD

指定容器启动后要干的事情;
当生成镜像后,启动容器docker run -it -p 8080:8080 tomcat镜像id /bin/bash,则容器启动后最后一行的CMD [“catalina.sh”, “run”]会被覆盖为相当于CMD ["/bin/bash", “run”]

CMD ["catalina.sh", "run"]

和RUN的区别:
RUN是在docker build时运行;
CMD是在docker run时运行;

  1. ENTRYPOINT

用来指定一个容器启动时要运行的命令
类似于CMD,但是ENTRYPOINT不会被docker run 后面的命令覆盖,而且这些命令行参数会被当做参数送给ENTRYPOINT指令指定的程序
在这里插入图片描述

四、案例
  1. 编写Dockerfile文件

FROM centos:7
MAINTAINER answer<answer@126.com> 
ENV MYPATH /usr/local
WORKDIR $MYPATH 
#安装vim编辑器
RUN yum -y install vim
#安装ifconfig命令查看网络IP
RUN yum -y install net-tools
#安装java8及lib库
RUN yum -y install glibc.i686
RUN mkdir /usr/local/java
#ADD是相对路径jar,把jdk-8u192-linux-x64.tar.gz添加到容器中,安装包必须要和Dockerfile文件在同一位置
ADD jdk-8u192-linux-x64.tar.gz /usr/local/java/
#配置java环境变量
ENV JAVA_HOME /usr/local/java/jdk1.8.0_192
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
ENV PATH $JAVA_HOME/bin:$PATH 
EXPOSE 80 
CMD echo $MYPATH
CMD echo "success--------------ok"
CMD /bin/bash
 
  1. 制作镜像
docker build -t newcentos:0.1 .

在这里插入图片描述

  1. 测试新的centOS镜像
    在这里插入图片描述
### 创建和使用 Dockerfile #### 编写 Dockerfile Dockerfile 是一种用于定义 Docker 镜像的脚本文件,它包含了构建镜像所需的一系列指令。以下是编写 Dockerfile 的基本结构和常用指令: 1. **FROM**: 定义基础镜像,这是所有 Dockerfile 中的第一个非注释指令。 示例:`FROM ubuntu:latest` 表示基于最新的 Ubuntu 镜像创建新的镜像[^4]。 2. **ENV**: 设置环境变量。 示例:`ENV JAVA_HOME /usr/local/jdk1.8.0_71` 用来设置 `JAVA_HOME` 环境变量[^4]。 3. **ADD/COPY**: 添加或复制文件到镜像中。两者的主要区别在于 `ADD` 支持远程 URL 和自动解压功能,而 `COPY` 更加直观简单。 示例:`COPY app.jar /app/` 将本地的 `app.jar` 文件复制到容器内的 `/app/` 路径下[^3]。 4. **RUN**: 执行命令以安装软件或其他必要的操作。这些命令将在构建过程中被执行。 示例:`RUN apt-get update && apt-get install -y curl` 更新包管理器并安装 `curl` 工具[^4]。 5. **EXPOSE**: 声明容器运行时监听的端口号。这不会实际开放端口,仅作为文档用途供客户端参考。 示例:`EXPOSE 8080` 指定容器内部服务使用的端口为 8080[^4]。 6. **CMD 或 ENTRYPOINT**: 定义容器启动时默认执行的命令。注意,一个 Dockerfile 只能有一个有效的 CMD 指令,若有多个,则只有最后一条生效;ENTRYPOINT 则更常用于固定入口程序调用方式。 示例:`CMD ["java", "-jar", "/app/app.jar"]` 启动 Java 应用程序[^3]。 #### 使用 Dockerfile 构建镜像 通过 `docker build` 命令可以依据 Dockerfile 来生成自定义镜像。具体语法如下: ```bash docker build [OPTIONS] PATH | URL | - ``` 常见选项包括 `-t` 设定新镜像的名字与标签以及 `-f` 明确指出所采用的 Dockerfile 名字及其位置[^2]。例如,在当前目录存在名为 php.Dockerfile 的情况下,可通过下面这条语句建立镜像: ```bash docker build -f ./php.Dockerfile -t my-php-app:v1 . ``` #### 运行由 Dockerfile 构建出来的镜像 一旦成功构建好镜像之后,就可以利用 `docker run` 把这个静态映射变成动态实例化的过程——也就是常说的“跑起来”。其基本形式如下所示: ```bash docker run [OPTIONS] IMAGE [COMMAND] [ARG...] ``` 举个例子来说就是假如前面提到过的那个 PHP Web Server 类型的应用程序已经打包完毕成为镜像叫做 `my-php-app:v1`,那么现在想让它作为一个独立的服务进程开始运作则只需要输入类似这样的东西就可以了: ```bash docker run -d --name my-running-server -p 8080:80 my-php-app:v1 ``` 这里的关键部分解释一下,“-d”表示后台模式运行容器,“--name”赋予特定名字给这次启动的新实体以便后续识别方便,“-p”实现主机端口向容器内暴露出去的功能从而允许外部访问[^3]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dream答案

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值