百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

使用Dockerfile build镜像

wptr33 2025-01-09 16:35 18 浏览

Docker映像可以看作是Docker容器的压缩包,包含了应用程序以及运行应用程序所需的依赖,容器是映像的运行时实例。

一般构建镜像都是使用dockerfile进行构建而不是docker commit,虽然commit也会创建新层,但这是一种手工创建镜像的方式,容易出错,效率低,使用者并不知道镜像是如何创建出来的,无法对镜像进行审计,存在安全隐患。

我们将解释什么是Dockerfile,如何创建Dockerfile,以及如何使用Dockerfile构建Docker映像。

What is Dockerfile

Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。

下面列出了一些最常用的Dockerfile指令的简短说明,指令不区分大小写,但约定名称使用大写。

ENV

- 设置环境变量,定义了环境变量,后续的指令中,就可以使用这个环境变量。

ARG

- 与 ENV 作用一致。不过作用域不一样。ARG 设置的环境变量仅对 Dockerfile 内有效,也就是说只有 docker build 的过程中有效,构建好的镜像内不存在此环境变量。

FROM

- 用于构建新镜像的基础镜像。此指令必须是Dockerfile中的第一条非注释指令。此规则的唯一例外是当您希望在from参数中使用变量时。在这种情况下,FROM前面可以有一条或多条ARG指令。

LABEL

- 用于向镜像添加元数据,如描述、版本、作者等。可以指定多个标签,每个标签指令都是一个键值对。

ADD

- 用于将文件和目录从指定源复制到docker镜像上的指定目标。源可以是本地文件、目录或URL。如果源文件是本地tar归档文件,那么它将自动解压缩到Docker映像中。

COPY

- 与ADD类似,但源只能是本地文件或目录。

RUN

- 此指令中指定的命令将在build过程中执行。每个运行指令在当前镜像的顶部创建一个新层。

CMD

- 用于指定在运行容器时将执行的命令。在Dockerfile中只能使用一条CMD指令。

类似于 RUN 指令,用于运行程序,但二者运行的时间点不同:

  • CMD 在docker run 时运行。
  • RUN 是在 docker build。

注意:如果 Dockerfile 中如果存在多个 CMD 指令,仅最后一个生效,CMD 指令可被 docker run 命令行参数中指定的指令所覆盖。

ENTRYPOINT

- 与CMD类似,此指令定义运行容器时将执行的命令。

但其不会被 docker run 的命令行参数指定的指令所覆盖,而且这些命令行参数会被当作参数送给 ENTRYPOINT 指令指定的程序。

注意:如果 Dockerfile 中如果存在多个 ENTRYPOINT 指令,仅最后一个生效。

可以搭配 CMD 命令使用:一般是变参才会使用 CMD ,这里的 CMD 等于是在给 ENTRYPOINT 传参,示例:

FROM nginx

ENTRYPOINT ["nginx", "-c"] # 定参
CMD ["/etc/nginx/nginx.conf"] # 变参 

WORKDIR

- 此指令为RUN、CMD、ENTRYPOINT、COPY和ADD指令设置当前工作目录。

USER

- 设置在运行CMD、ENTRYPOINT、COPY和ADD指令时要使用的用户名或组。

VOLUME

- 将主机目录装载到容器。

EXPOSE

- 用于指定容器在运行时侦听的端口。


要排除添加到映像中的文件和目录,请在上下文目录中创建一个.dockerignore文件。.dockerignore的语法类似于Git的.gitignore文件。

Create a Dockerfile

创建Docker镜像通常是从Docker Hub拉取现有镜像,最常用的基本镜像是Alpine,因为它很小,并且经过优化,可以在RAM中运行。

在这个例子中,我们将创建一个Redis Docker映像。我们使用ubuntu 18.04作为基本镜像。

首先,创建一个目录用于存放Dockerfile和程序所用到的文件:

mkdir ~/redis_docker

进入该目录创建Dockerfile,内容如下:

FROM ubuntu:18.04

RUN apt-get update && \
    apt-get install -y redis-server && \
    apt-get clean

EXPOSE 6379

CMD ["redis-server", "--protected-mode no"]
  • 第1行定义了以ubuntu:18.04为基本镜像。
  • 从第3行开始的RUN指令将更新apt索引,安装“redis server”包并清理apt缓存。说明中使用的命令与在Ubuntu上安装redis时使用的命令相同。
  • EXPOSE指令定义redis服务器侦听的端口。
  • 在最后一行中,我们使用CMD指令设置容器运行时将执行的默认命令。

Building the Image

下一步是构建镜像。要执行此操作,请从Dockerfile所在的目录运行以下命令:

docker build -t linuxize/redis .

选项-t指定镜像名称一般以“username/imagename:tag”格式的用户名和标记(可选)。

构建过程的输出将如下所示:

Sending build context to Docker daemon  3.584kB
Step 1/4 : FROM ubuntu:18.04
 ---> 7698f282e524
Step 2/4 : RUN apt-get update &&     apt-get install -y gosu redis-server &&     apt-get clean
 ---> Running in e80d4dd69263
...
Removing intermediate container e80d4dd69263
 ---> e19fb7653fca
Step 3/4 : EXPOSE 6379
 ---> Running in 8b2a45f457cc
Removing intermediate container 8b2a45f457cc
 ---> 13b92565c201
Step 4/4 : CMD ["redis-server", "--protected-mode no"]
 ---> Running in a67ec50c7048
Removing intermediate container a67ec50c7048
 ---> d8acc14d9b6b
Successfully built d8acc14d9b6b
Successfully tagged linuxize/redis:latest

构建完成后,可使用docker image ls查看镜像列表。

docker image ls
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
linuxize/redis      latest              d8acc14d9b6b        4 minutes ago       100MB
ubuntu              18.04               7698f282e524        5 days ago          69.9MB

Running a Container

现在镜像已创建,可以通过以下命令运行容器:

docker run-d-p 6379:6379 --name redis linuxize/redis

-d选项告诉Docker以后台模式运行容器,-p 6379:6379选项将容器6379端口映射到主机的6379端口,--name redis选项指定容器名称。最后一个参数linuxize/redis是用于运行容器的镜像名称。

容器启动时,使用以下命令列出所有正在运行的容器:

docker container ls
CONTAINER ID        IMAGE                   COMMAND                  CREATED             STATUS              PORTS                    NAMES
6b7d424cd915        linuxize/redis:v0.0.1   "redis-server '--pro…"   5 minutes ago       Up 5 minutes        0.0.0.0:6379->6379/tcp   redis

结论

本教程仅介绍使用DockerFile构建镜像的基础知识。要了解有关如何编写DockerFile和最佳实践的更多信息,请参阅DockerFile的最佳实践。Best practices for writing Dockerfiles | Docker Documentation

相关推荐

Linux文件系统操作常用命令(linux文件内容操作命令)

在Linux系统中,有一些常用的文件系统操作命令,以下是这些命令的介绍和作用:#切换目录,其中./代表当前目录,../代表上一级目录cd#查看当前目录里的文件和文件夹ls#...

别小看tail 命令,它难倒了技术总监

我把自己以往的文章汇总成为了Github,欢迎各位大佬star...

lnav:基于 Linux 的高级控制台日志文件查看器

lnav是一款开源的控制台日志文件查看器,专为Linux和Unix-like系统设计。它通过自动检测日志文件的格式,提取时间戳、日志级别等关键信息,并将多个日志文件的内容按时间顺序合并显示,...

声明式与命令式代码(声明模式和命令模式)

编程范式中的术语和差异信不信由你,你可能已经以开发人员的身份使用了多种编程范例。因为没有什么比用编程理论招待朋友更有趣的了,所以这篇文章可以帮助您认识代码中的流行范例。命令式编程命令式编程是我们从As...

linux中的常用命令(linux常用命令和作用)

linux中的常用命令linux中的命令统称shell命令shell是一个命令行解释器,将用户命令解析为操作系统所能理解的指令,实现用户与操作系统的交互shell终端:我们平时输入命令,执行程序的那个...

提高工作效率的--Linux常用命令,能够决解95%以上的问题

点击上方关注,第一时间接受干货转发,点赞,收藏,不如一次关注评论区第一条注意查看回复:Linux命令获取linux常用命令大全pdf+Linux命令行大全pdf...

如何限制他人操作自己的电脑?(如何控制别人的电脑不让发现)

这段时间,小猪罗志祥正处于风口浪尖,具体是为啥?还不知道的小伙伴赶紧去补一下最近的娱乐圈八卦~简单来说,就是我们的小罗同事,以自己超强的体力,以及超强的时间管理能力,重新定义了「多人运动」的含义,重新...

最通俗易懂的命令模式讲解(命令模式百科)

我们先不讲什么是命令模式,先通过一个场景来引出命令模式,看看命令模式能解决什么样的问题。现在有一个渣男张三,他有还几个女朋友,你现在是不是还是单身狗,你就说你气不气?然后他需要每天分别叫几个女朋友起床...

互联网大厂后端必看!Spring Boot 中Runtime执行与停止命令?

你是否曾在使用SpringBoot开发项目时,遇到需要执行系统命令的场景?比如调用脚本进行文件处理,又或是启动外部程序?很多后端开发人员会使用Processexec=Runtime.get...

Linux 常用命令(linux常用的20个命令面试)

日志排查类操作命令...

Java字节码指令:if_icmpgt(0xA3)(java字节码使用的汇编语言)

if_icmpgt是Java字节码中的一条条件跳转指令,其全称是"IfIntegerCompareGreaterThan"。它用于比较两个整数值的大小。如果栈顶的第一个...

外贸干货|如何增加领英的曝光量和询盘

#跨境电商#...

golang执行linux命令(golang调用shell脚本)

需求需要通过openssl生成rsa秘钥,然后保存该秘钥。代码实例packagemainimport("io/ioutil""bytes"&...

LINUX磁盘挂载(linux磁盘挂载到windows)

1、使用root用户查看磁盘挂载情况:fdisk-l2、使用df查看当前磁盘挂载情况,根据和fdisk-l的结果进行对比,查看还有那些磁盘未使用3、挂载:mount磁盘挂载路径...

Linux命令学习——nl命令(linux ln命令的使用)

nl命令主要功能为每一个文件添加行号,每一个输入的文件添加行号后发送到标准输出。当没有文件或文件为-时,读取标准输入...