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

使用Dockerfile build镜像 dockerfile中指定基础镜像的指令

nanshan 2024-12-28 14:31 16 浏览 0 评论

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

相关推荐

Let’s Encrypt免费搭建HTTPS网站

HTTPS(全称:HyperTextTransferProtocoloverSecureSocketLayer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入...

使用Nginx配置TCP负载均衡(nginx tcp负载)

假设Kubernetes集群已经配置好,我们将基于CentOS为Nginx创建一个虚拟机。以下是实验种设置的详细信息:Nginx(CenOS8Minimal)-192.168.1.50Kube...

Nginx负载均衡及支持HTTPS与申请免费SSL证书

背景有两台minio文件服务器已做好集群配置,一台是192.168.56.41:9000;另一台是192.168.56.42:9000。应用程序通过Nginx负载均衡调用这两台minio服务,减轻单点...

HTTPS配置实战(https配置文件)

原因现在网站使用HTTPS是规范操作之一,前些日子买了腾讯云服务,同时申请了域名http://www.asap2me.top/,目前该域名只支持HTTP,想升级为HTTPS。关于HTTPS的链接过程大...

只有IP地址没有域名实现HTTPS访问方法

一般来说,要实现HTTPS,得有个注册好的域名才行。但有时候呢,咱只有服务器的IP地址,没注册域名,这种特殊情况下,也能照样实现HTTPS安全访问,按下面这些步骤来就行:第一步,先确认公网...

超详解:HTTPS及配置Django+HTTPS开发环境

众所周知HTTP协议是以TCP协议为基石诞生的一个用于传输Web内容的一个网络协议,在“网络分层模型”中属于“应用层协议”的一种。在这里我们并不研究该协议标准本身,而是从安全角度去探究使用该协议传输数...

Godaddy购买SSL之后Nginx配置流程以及各种错误的解决

完整流程:参考地址:https://sg.godaddy.com/zh/help/nginx-generate-csrs-certificate-signing-requests-3601生成NGI...

Nginx从安装到高可用,一篇搞定(nginx安装与配置详解)

一、Nginx安装1、去官网http://nginx.org/下载对应的nginx包,推荐使用稳定版本2、上传nginx到linux系统3、安装依赖环境(1)安装gcc环境yuminstallgc...

阿里云免费证书申请,配置安装,使用tomcat,支持http/https访问

参数说明商品类型默认已选择云盾证书服务(无需修改)。云盾证书服务类型SSL证书服务的类型。默认已选择云盾SSL证书(无需修改),表示付费版SSL证书。如果您需要免费领取或付费扩容DV单域名证书【免费试...

你试过两步实现Nginx的规范配置吗?极速生成Nginx配置小工具

NGINX是一款轻量级的Web服务器,最强大的功能之一是能够有效地提供HTML和媒体文件等静态内容。NGINX使用异步事件驱动模型,在负载下提供可预测的性能。是当下最受欢迎的高性能的Web...

从零开始搭建HTTPS服务(搭建https网站)

搭建HTTPS服务的最初目的是为了开发微信小程序,因为wx.request只允许发起HTTPS请求,并且还必须和指定的域名进行网络通信。要从零开始搭建一个HTTPS的服务需要下面4...

群晖NAS使用官网域名和自己的域名配置SSL实现HTTPS访问

安全第一步,群晖NAS使用官网域名和自己的域名配置SSL实现HTTPS访问【新手导向】NAS本质还是一个可以随时随地访问的个人数据存储中心,我们在外网访问的时候,特别是在公网IP下,其实会面临着很多安...

让网站快速升级HTTPS协议提高安全性

为什么用HTTPS网络安全越来越受到重视,很多互联网服务网站,都已经升级改造为https协议。https协议下数据包是ssl/tcl加密的,而http包是明文传输。如果请求一旦被拦截,数据就会泄露产生...

用Https方式访问Harbor-1.9版本(https访问流程)

我上周在头条号写过一篇原创文章《Docker-Harbor&Docker-kitematic史上最详细双系统配置手册》,这篇算是它的姊妹篇吧。这篇文章也将用到我在头条写的另一篇原创文章的...

如何启用 HTTPS 并配置免费的 SSL 证书

在Linux服务器上启用HTTPS并配置免费的SSL证书(以Let'sEncrypt为例)可以通过以下步骤完成:---###**一、准备工作**1.**确保域名已解析**...

取消回复欢迎 发表评论: