您当前的位置:首页 > 电脑百科 > 程序开发 > 容器

保持Dockerfile整洁的5个技巧

时间:2020-09-23 09:35:13  来源:  作者:
重构:保持Dockerfile整洁的5个技巧

 

Dockerfile超出合理范围时,会出现以下问题:

  • 很难理解和维护-我们需要阅读数百行以了解所有依赖关系
  • 在这么多行之间可能忽略一个明显的安全问题
  • 当每个人都在更改同一文件时,Git将引发更多冲突
  • 如果我们不清理每个依赖项,可能会导致镜像体积沉重

最好的解决方案是将Dockerfile拆分为多个Dockerfile,以使我们的Dockerfile更小,更易于理解和维护。

这里是一些减少Dockerfile大小的技巧。

重构1:从其官方镜像中获取依赖

避免创建从官方镜像复制的工件。例如:我需要使用terraform没必要再重新apt-get安装了,可以直接使用带有terraform的官方镜像。

原始Dockerfile

FROM golang:1.12
RUN apt-get update && 
    apt-get upgrade -y && 
    apt-get install -y git openssh-client zip
WORKDIR $GOPATH/src/github.com/hashicorp/terraform
RUN git clone https://github.com/hashicorp/terraform.git ./ && 
    git checkout v0.12.9 && 
    ./scripts/build.sh
WORKDIR /my-config
COPY . /my-config/
CMD ["terraform init"]

重构后Dockerfile

FROM hashicorp/terraform:0.12.9 AS terraform
FROM golang:1.12
COPY --from=terraform /go/bin/terraform /usr/bin/terraform
WORKDIR /my-config
COPY . /my-config/
CMD ["terraform init"]

重构2:将依赖项提取到另一个Dockefile中

如果没有正式镜像,您可以从中提取工件,则应将其构建分离到另一个Dockefile中。然后将工件复制到原始Dockerfile中。

原始Dockerfile:

FROM golang:1.12
RUN apt-get update && 
    apt-get upgrade -y && 
    apt-get install -y git openssh-client
WORKDIR /go/src/gitlab.com/sahilm/
RUN git clone https://github.com/sahilm/yamldiff.git
RUN cd yamldiff && 
    go get -u github.com/golang/dep/cmd/dep && 
    dep ensure && 
    GOOS=linux go build -o /usr/local/yamldiff
WORKDIR /my-App
COPY . /my-app/
CMD ["./run.sh"]

重构:用于yamldiff的Dockerfile。

FROM golang:1.12
RUN apt-get update && 
    apt-get upgrade -y && 
    apt-get install -y git openssh-client
WORKDIR /go/src/gitlab.com/sahilm/
RUN git clone https://github.com/sahilm/yamldiff.git
RUN cd yamldiff && 
    go get -u github.com/golang/dep/cmd/dep && 
    dep ensure && 
    GOOS=linux go build -o /usr/local/yamldiff
CMD ["bash"]

重构:应用程序的Dockerfile。

FROM Marvalero/yamldiff:latest AS yamldiff
FROM golang:1.12
COPY --from=yamldiff /usr/bin/yamldiff /usr/bin/yamldiff
WORKDIR /my-app
COPY . /my-app/
CMD ["./run.sh"]

重构3:将镜像分成多个阶段

Docker具有多阶段功能,当您的Dockerfile具有不同的部分时,它会派上用场。最常见的用例是进行构建,然后在主镜像中复制工件。具有不同的阶段可以使您的Dockerfile更加清晰和安全。

FROM golang:1.12
RUN apt-get update && 
    apt-get upgrade -y && 
    apt-get install -y git openssh-client
WORKDIR /go/src/gitlab.com/sahilm/
RUN git clone https://github.com/sahilm/yamldiff.git
RUN cd yamldiff && 
    go get -u github.com/golang/dep/cmd/dep && 
    dep ensure && 
    GOOS=linux go build -o /usr/local/yamldiff
CMD ["bash"]

重构Dockerfile:

FROM golang:1.12 as Builder
RUN apt-get update && 
    apt-get upgrade -y && 
    apt-get install -y git openssh-client
WORKDIR /go/src/gitlab.com/sahilm/
RUN git clone https://github.com/sahilm/yamldiff.git
RUN cd yamldiff && 
    go get -u github.com/golang/dep/cmd/dep && 
    dep ensure && 
    GOOS=linux go build -o /usr/local/yamldiff
FROM ubuntu:18.04
COPY --from=Builder /usr/local/yamldiff /usr/local/yamldiff
CMD ["bash"]

重构4:对多行参数进行排序

尽可能对多行参数进行排序。这有助于仔细检查没有重复的程序包。

FROM ubuntu:18.04
RUN apt-get -yqq install 
    ca-certificates 
    bash 
    jq 
    wget 
    curl 
    openssh-client 
    build-essential 
    libpng-dev 
    Python 
    zip
CDM ["bash"]

重构Dockerfile:

FROM ubuntu:18.04
RUN apt-get -yqq install 
    bash 
    build-essential 
    ca-certificates 
    curl 
    jq 
    libpng-dev 
    openssh-client 
    python 
    wget 
    zip
CDM ["bash"]

重构5:标签

在使用Docker镜像时,保持标签整洁也至关重要。我总是觉得拥有三种类型的标签非常有用:

  • 分支名称:标识特定分支的镜像的最新版本

注意:为什么不使用latest?使用时latest,我永远不知道它是表示整个存储库中的最新稳定版本还是最新版本。使用分支的名称(如master,feature/new-class等)指向一个分支最新版本是方式更直观。

  • 版本:需要区分修补程序和重大更改。我建议使用语义版本控制(major.minor.patch)。
  • 提交:我一直想知道标签所指向的提交。现在,您可以通过在存储库中创建版本标记来执行此操作。但是,当这不可能时,只需使用其Commit SHA标记镜像即可。

谢谢阅读,希望您可以更轻松地维护Dockerfile。



Tags:Dockerfile   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
虽然docker history命令可以看到所有历史层级的操作,但是还是需要手动去写Dockerfiledfimage就是这样一个工具dfimage是一个alpine的镜像,启动的时候,通过将docker.sock映射到...【详细内容】
2021-06-25  Tags: Dockerfile  点击:(112)  评论:(0)  加入收藏
1.DockerFile是什么? DockerFile是用来构建Docker镜像的构建文件,一般分为四部分:基础镜像信息、维护者信息、镜像操作指令和容器启动时执行指令,’#’ 为 Dockerfile...【详细内容】
2021-04-13  Tags: Dockerfile  点击:(238)  评论:(0)  加入收藏
今天分享给大家一个工具:minid工具下载直接访问github搜索:minid功能介绍 借助该工具可以优化Dockerfile,将Dockerfile的分层减少,从而达到使镜像变小的目的该工具主要是分析RU...【详细内容】
2021-03-03  Tags: Dockerfile  点击:(208)  评论:(0)  加入收藏
当Dockerfile超出合理范围时,会出现以下问题: 很难理解和维护-我们需要阅读数百行以了解所有依赖关系 在这么多行之间可能忽略一个明显的安全问题 当每个人都在更改同一文件...【详细内容】
2020-09-23  Tags: Dockerfile  点击:(74)  评论:(0)  加入收藏
接着文章「系统架构」如何使用Dockerfile制作Docker容器?(1)我们继续介绍ENV、ARG、VOLUME、EXPOSE、WORKDIR、USER、HEALTHCHECK、ONBUILD几个命令。7、ENV这个指令很简单,就...【详细内容】
2020-08-16  Tags: Dockerfile  点击:(77)  评论:(0)  加入收藏
制作Docker image 有两种方式:1. 使用 Docker container,直接构建容器,再导出成 image 使用2. 是使用 Dockerfile,将所有动作写在文件中,再 build 成 image。Dockerfile 的方式...【详细内容】
2020-08-03  Tags: Dockerfile  点击:(68)  评论:(0)  加入收藏
Dockerfile是Docker用来构建镜像的文本文件,包括自定义的指令和格式。可以通过docker build命令从Dockerfile中构建镜像。用户可以通过统一的语法命令来根据需求进行配置,通...【详细内容】
2020-03-08  Tags: Dockerfile  点击:(50)  评论:(0)  加入收藏
Dockerfile是Docker用来构建镜像的文本文件,包括自定义的指令和格式。可以通过docker build命令从Dockerfile中构建镜像。用户可以通过统一的语法命令来根据需求进行配置,通...【详细内容】
2020-03-05  Tags: Dockerfile  点击:(44)  评论:(0)  加入收藏
今天分享给大家一个工具:minid工具下载直接访问github搜索:minid功能介绍 借助该工具可以优化Dockerfile,将Dockerfile的分层减少,从而达到使镜像变小的目的该工具主要是分析RUN...【详细内容】
2019-11-26  Tags: Dockerfile  点击:(126)  评论:(0)  加入收藏
一、镜像制作的方法1.本地导入导出镜像请参考:Docker 架构原理及简单使用导出:docker save nginx >/tmp/nginx.tar.gz导入:docker load </tmp/nginx.tar.gz2.docker commit...【详细内容】
2019-11-20  Tags: Dockerfile  点击:(89)  评论:(0)  加入收藏
▌简易百科推荐
一、为什么要搭建主从架构呢1.数据安全,可以进行数据的备份。2.读写分离,大部分的业务系统来说都是读数据多,写数据少,当访问压力过大时,可以把读请求给到从服务器。从而缓解数据...【详细内容】
2021-12-15  实战Java    Tags:Docker   点击:(10)  评论:(0)  加入收藏
在网页中渲染公式一直是泛学术工具绕不开的一个功能,最近更新产品功能,正巧遇到了这个需求,于是使用容器方式简单实现了一个相对靠谱的公式渲染服务。分享出来,希望能够帮到有类...【详细内容】
2021-12-01  编程菌zfn    Tags:Docker   点击:(10)  评论:(0)  加入收藏
1.1 docker命令直接部署1.1.1 拉取镜像docker pull wurstmeister/zookeeperdocker pull wurstmeister/kafka1.1.2 启动zookeeper容器docker run -d --name myzookeeper -p 2...【详细内容】
2021-11-15  无    Tags:docker   点击:(47)  评论:(0)  加入收藏
01 前言 顺着docker的发展,很多测试的同学也已经在测试工作上使用docker作为环境基础去进行一些自动化测试,这篇文章主要讲述我们在docker中使用浏览器进行自动化测试如果可以...【详细内容】
2021-10-29  小码哥聊软件测试    Tags:Docker   点击:(42)  评论:(0)  加入收藏
因为你懂得的原因,下载docker镜像速度非常喜感,故收集几个国内常用的docker镜像。Docker中国区官方镜像地址:https://registry.docker-cn.com网易163的镜像http://hub-mirror.c...【详细内容】
2021-10-28  抓蛙程序猿    Tags:docker   点击:(48)  评论:(0)  加入收藏
环境:Spring5.3.10通常,应用程序开发人员不需要对ApplicationContext实现类进行子类化。相反,SpringIOC容器可以通过插入特殊集成接口的实现来扩展。使用BeanPostProcessor自定...【详细内容】
2021-10-26  Java网络研发架构师    Tags:Spring   点击:(33)  评论:(0)  加入收藏
我们在很多场景下都需要做笔记,来对抗遗忘,一份好的笔记不仅能在需要的时候供我们查阅,也能帮助我们归纳整理知识提高做事效率。 目前市面上有很多云笔记软件,体验上各有不同,但...【详细内容】
2021-10-11  运维贼船    Tags:docker   点击:(61)  评论:(0)  加入收藏
1. Nacos官网Nacos Docker 快速开始2. Clone 项目git clone https://github.com/nacos-group/nacos-docker.git3. cd 到nacos-docker 路径下 直接启动即可cd nacos-dockerdo...【详细内容】
2021-09-16  程序狗爱化妆    Tags:Nacos   点击:(109)  评论:(0)  加入收藏
今天不做保姆级教程,分享奶爸常用、好用的Docker应用。有了这些Docker,Nas的可玩性会大幅提高,有时候奶爸也在想,刨去官方套件不考虑的话,Nas真的是差不多。如果小伙伴们有需要,后...【详细内容】
2021-09-03  晋升奶爸的垃圾佬    Tags:Docker   点击:(167)  评论:(0)  加入收藏
环境要求 ubuntu系统:20.04 docker版本:20.10.7 redis版本:6.0.6步骤由于我这里已经有相应的redis镜像,这里就不记录了,关于docker一些基础知识可以看我以前的笔记开启3台re...【详细内容】
2021-07-26  石老师小跟班    Tags:Redis主从复制   点击:(117)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条