Docker(二)

Dockerfile文件

一、概述

Dockfile文件是镜像生成的一种方式。Dockerfile 是一个文本格式的配置文件,用户可以使用 Dockerfile 快速创建自定义的镜像。Dockerfile文件中的每一个命令都会创建镜像的一层。

二、常见命令

命令字 作用 语法
FROM 指定基础镜像,并且必须是第一条指令。 FROM <image> FROM <image>:<tag> FROM <image>:<digest>
RUN 镜像创建时运行指定的命令。 注意:多行命令不要写多个RUN,原因是Dockerfile中每一个指令都会建立一层. 多少个RUN就构建了多少层镜像,会造成镜像的臃肿、多层,不仅仅增加了构件部署的时间,还容易出错。 linux操作系统上默认 /bin/sh -c RUN书写时的换行符是 \ RUN command RUN ["executable", "param1", "param2"]
CMD 功能为容器启动时要运行的命令. 注意:里边包括参数的一定要用双引号,就是",不能是单引号。千万不能写成单引号。 原因是参数传递后,docker解析的是一个JSON array CMD ["executable","param1","param2"] CMD ["param1","param2"] CMD command param1 param2
LABEL 为镜像指定标签,一个Dockerfile种可以有多个LABEL 注意:LABEL会继承基础镜像中的LABEL,如遇到key相同,则值覆盖 LABEL <key>=<value> <key>=<value> <key>=<value> ...
MAINTAINER 指定作者 MAINTAINER name
EXPOSE 暴漏容器运行时的监听端口给外部,但是EXPOSE并不会使容器访问主机的端口 EXPOSE port
ENV 设置环境变量,多环境变量使用空格隔开 ENV <key><value> ENV <key>=<value> <key>=<value> <key>=<value>...
ADD 把文件复制到镜像中;如果把<src>写成一个url,那么ADD就类似于wget命令; 尽量不要把<scr>写成一个文件夹,如果<src>是一个文件夹了,复制整个目录的内容,包括文件系统元数据 能够将压缩文件自动解压 ADD <src>... <dest> ADD ["<src>",... "<dest>"]
SHELL 设置默认的 shell 环境。默认情况下,Docker 使用 /bin/sh -c SHELL ["<shell>", "<shell参数>"]
COPY 把文件复制到镜像中; 与ADD的区别:COPY的<src>只能是本地文件,其他用法一致 COPY <src>... <dest> COPY ["<src>",... "<dest>"]
ENTRYPOINT 容器启动时的默认命令; 与CMD比较说明: 相同点: 只能写一条,如果写了多条,那么只有最后一条生效 容器启动时才运行,运行时机相同 不同点: ENTRYPOINT不会被docker run运行的command覆盖,而CMD则会被覆盖 如果我们在Dockerfile种同时写了ENTRYPOINT和CMD,并且CMD指令不是一个完整的可执行命令,那么CMD指定的内容将会作为ENTRYPOINT的参数 如果我们在Dockerfile种同时写了ENTRYPOINT和CMD,并且CMD是一个完整的指令,那么它们两个会互相覆盖,谁在最后谁生效。 ENTRYPOINT ["executable", "param1", "param2"] ENTRYPOINT command param1 param2
VOLUME 实现挂载功能,可以将内部文件夹或者其他容器中得文件夹挂载到这个容器中,一般的使用场景为需要持久化存储数据时; ["/data"]可以是一个JsonArray ,也可以是多个值。所以如下几种写法都是正确的 VOLUME ["/var/log/"] VOLUME /var/log VOLUME /var/log /var/db 注意:VOLUME命令在Dockerfile中只能用来创建挂载点,不能指定已经存在的目录作为挂载点。如果指定的目录已经存在,但没有使用VOLUME命令,Docker将会将其作为普通目录对待,而不会创建一个挂载点。 VOLUME ["/data"]
USER 设置启动容器的用户,可以是用户名或UID 注意:如果设置了容器以daemon用户去运行,那么RUN, CMD 和 ENTRYPOINT 都会以这个用户去运行 USER daemo USER UID
WORKDIR 设置工作目录,对RUN,CMD,ENTRYPOINT,COPY,ADD生效。如果不存在则会创建,也可以设置多次;默认工作目录是:/ WORKDIR /path/to/workdir
ARG 设置变量命令,ARG命令定义了一个变量;在docker build创建镜像的时候,使用 --build-arg <varname>=<value>来指定参数;如果用户在build镜像时指定了一个参数没有定义在Dockerfile种,那么将有一个Warning 提示如下: [Warning] One or more build-args [foo] were not consumed. 如果我们给了ARG定义的参数默认值,那么当build镜像时没有指定参数值,将会使用这个默认值 ARG <name>[=<default value>]
STOPSIGNAL 当容器退出时给系统发送什么样的指令 STOPSIGNAL signal
HEALTHCHECK 容器健康状况检查命令; 第一个的功能是在容器内部运行一个命令来检查容器的健康状况 第二个的功能是在基础镜像中取消健康检查命令 [OPTIONS]的选项支持以下三中选项: interval=DURATION 两次检查默认的时间间隔为30秒 timeout=DURATION 健康检查命令运行超时时长,默认30秒 retries=N 当连续失败指定次数后,则容器被认为是不健康的,状态为unhealthy,默认次数是3 注意: HEALTHCHECK命令只能出现一次,如果出现了多次,只有最后一个生效。 CMD后边的命令的返回值决定了本次健康检查是否成功,具体的返回值如下: 0: success - 表示容器是健康的 1: unhealthy - 表示容器已经不能工作了 2: reserved - 保留值 HEALTHCHECK [OPTIONS] CMD command HEALTHCHECK NONE

三、制作镜像

3.1、编写dockerfile文件

FROM ubuntu

RUN apt update && apt install -y gcc make wget && apt install -y libpcre3 libpcre3-dev zlib1g-dev openssl libssl-dev

RUN wget http://nginx.org/download/nginx-1.24.0.tar.gz && tar xf nginx-1.24.0.tar.gz && cd nginx-1.24.0 && ./configure --prefix=/usr/local/nginx && make && make install

EXPOSE 80

CMD ["/usr/local/nginx/sbin/nginx", "-g", "daemon off;"]

This my first nginx Dockerfile

Version 1.0

Base images 基础镜像

FROM centos:7

#MAINTAINER 维护者信息

MAINTAINER bertwu

#ENV 设置环境变量

ENV PATH /usr/local/nginx/sbin:$PATH

#ADD 文件放在当前目录下,拷过去会自动解压

ADD nginx-1.8.0.tar.gz /usr/local/

ADD epel-release-latest-7.noarch.rpm /usr/local/

#RUN 执行以下命令

RUN rpm -ivh /usr/local/epel-release-latest-7.noarch.rpm

RUN yum install -y wget lftp gcc gcc-c++ make openssl-devel pcre-devel pcre && yum clean all

RUN useradd -s /sbin/nologin -M www

#WORKDIR 相当于cd

WORKDIR /usr/local/nginx-1.8.0

RUN ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_ssl_module --with-pcre && make && make install

RUN echo "daemon off;" >> /etc/nginx.conf

#EXPOSE 映射端口

EXPOSE 80

#CMD 运行以下命令

CMD ["nginx"]

3.2、构建镜像

docker build命令解析

-t, --tag : 给镜像打标签,格式为 name:tag

docker build -t myimage:latest .

②**-f, --file**: 指定 Dockerfile 的路径。

docker build -f /path/to/Dockerfile .

③**--build-arg** : 设置构建参数,可以在 Dockerfile 中使用 ARG 指令引用。

docker build --build-arg MY_VAR=value .

④**--no-cache**: 不使用缓存,强制重新构建所有层。

docker build --no-cache .

⑤**--pull**: 总是尝试拉取最新的基础镜像。

docker build --pull .

⑥**--compress**: 使用 gzip 压缩构建上下文。

docker build --compress .

⑦**--quiet, -q**: 静默模式,只输出镜像 ID。

docker build -q .

⑧**--target**: 指定构建阶段,适用于多阶段构建。

docker build --target mystage .

⑨**--network**: 指定构建过程中使用的网络模式。

docker build --network mynetwork .

⑩**--label**: 给镜像添加元数据标签。

docker build --label version=1.0 .

例:构建一个带有特定标签和构建参数的镜像

docker build -t myimage:1.0 --build-arg MY_VAR=value .

相关推荐
实心儿儿2 小时前
C++ —— 进程控制 - 进程程序替换
linux·运维·服务器
SilentSamsara2 小时前
Service 与 Ingress:从 ClusterIP 到云厂商 ALB 的完整流量路径
linux·运维·服务器·微服务·kubernetes·k8s·运维开发
霸道流氓气质2 小时前
Bat中实现简单运维脚本示例-启动redis、检测指定端口是否占用、占用则杀死进程、等待指定秒数、启动jar包
运维·redis·jar
qq_348231852 小时前
Ubuntu 24.04 环境配置 AI自动化编程 gstack
linux·运维·人工智能·ubuntu
小小仙。3 小时前
IT自学第四十天
spring·docker
小则又沐风a3 小时前
Linux使用指南和基础指令(1)
java·linux·运维
ALINX技术博客3 小时前
【黑金云课堂】FPGA技术教程Linux开发:Petalinux安装
linux·运维·fpga开发
qq7590353663 小时前
docker一键部署SQLynx,轻量级数据库管理平台
数据库·docker·容器
SilentSamsara3 小时前
ConfigMap 与 Secret:配置注入的四种姿势与安全边界
linux·运维·服务器·安全·微服务·kubernetes·k8s