11-Dockerfile

简介: Dockerfile是构建Docker镜像的脚本文件,包含FROM、RUN、CMD等指令,按顺序执行,每条指令创建新的镜像层。FROM指定基础镜像,RUN在构建时运行命令,CMD设置容器启动命令,ENTRYPOINT则定义不可被覆盖的启动命令。ADD/COPY复制文件,EXPOSE暴露端口,WORKDIR设置工作目录。构建时通过docker build生成镜像,未命名镜像可能产生虚悬镜像(<none>),可用docker image prune清理。

11-Dockerfile

DockerfileDockerfile是用来构建Docker镜像的文本文件,是由一条条构建镜像所需的指令和参数构成的脚本。构建步骤:编写Dockerfile文件docker build命令构建镜像docker run依据镜像运行容器实例构建过程Dockerfile编写:每条保留字指令都必须为大写字母,且后面要跟随至少一个参数指令按照从上到下顺序执行#表示注释每条指令都会创建一个新的镜像层并对镜像进行提交Docker引擎执行Docker的大致流程:docker从基础镜像运行一个容器执行一条指令并对容器做出修改执行类似docker commit的操作提交一个新的镜像层docker再基于刚提交的镜像运行一个新容器执行Dockerfile中的下一条指令,直到所有指令都执行完成Dockerfile保留字FROM基础镜像,当前新镜像是基于哪个镜像的,指定一个已经存在的镜像作为模板。Dockerfile第一条必须是FROM

MAINTAINER镜像维护者的姓名和邮箱地址RUN容器构建时需要运行的命令。有两种格式: shell格式   exec格式  RUN是在docker build时运行EXPOSE当前容器对外暴露出的端口。WORKDIR指定在创建容器后, 终端默认登录进来的工作目录。USER指定该镜像以什么样的用户去执行,如果不指定,默认是root。(一般不修改该配置)ENV用来在构建镜像过程中设置环境变量。这个环境变量可以在后续的任何RUN指令或其他指令中使用VOLUME容器数据卷,用于数据保存和持久化工作。类似于 docker run 的-v参数。ADD将宿主机目录下(或远程文件)的文件拷贝进镜像,且会自动处理URL和解压tar压缩包。COPY类似ADD,拷贝文件和目录到镜像中。将从构建上下文目录中<源路径>的文件目录复制到新的一层镜像内的<目标路径>位置。CMD指定容器启动后要干的事情。有两种格式: shell格式   exec格式   参数列表格式  Dockerfile中如果出现多个CMD指令,只有最后一个生效。CMD会被docker run之后的参数替换。例如,对于tomcat镜像,执行以下命令会有不同的效果:CMD是在docker run时运行,而 RUN是在docker build时运行。ENTRYPOINT用来指定一个容器启动时要运行的命令。类似于CMD命令,但是ENTRYPOINT不会被docker run后面的命令覆盖,这些命令参数会被当做参数送给ENTRYPOINT指令指定的程序。ENTRYPOINT可以和CMD一起用,一般是可变参数才会使用CMD,这里的CMD等于是在给ENTRYPOINT传参。当指定了ENTRYPOINT后,CMD的含义就发生了变化,不再是直接运行期命令,而是将CMD的内容作为参数传递给ENTRYPOINT指令,它们两个组合会变成 <ENTRYPOINT> "<CMD>"。例如:对于此Dockerfile,构建成镜像 nginx:test后,如果执行;docker run nginx test,则容器启动后,会执行 nginx -c /etc/nginx/nginx.confdocker run nginx:test /app/nginx/new.conf,则容器启动后,会执行 nginx -c /app/nginx/new.conf构建镜像创建名称为Dockerfile的文件,示例:编写完成之后,将其构建成docker镜像。命令:

Shell

运行代码复制代码

1

2

3

# 注意:定义的TAG后面有个空格,空格后面有个点

# docker build -t 新镜像名字:TAG .

docker build -t ubuntu:1.0.1 .

虚悬镜像虚悬镜像:仓库名、标签名都是 <none>的镜像,称为 dangling images(虚悬镜像)。在构建或者删除镜像时可能由于一些错误导致出现虚悬镜像。例如:

Shell

运行代码复制代码

1

2

# 构建时候没有镜像名、tag

docker build .

列出docker中的虚悬镜像:

Shell

运行代码复制代码

1

docker image ls -f dangling=true

虚悬镜像一般是因为一些错误而出现的,没有存在价值,可以删除:

Shell

运行代码复制代码

1

2

# 删除所有的虚悬镜像

docker image prune


相关文章
|
安全 Linux Windows
Linux堡垒机如何实现敏感指令审计?
目前Linux服务器是堡垒机的主要应用场景,因为市面上大部分堡垒机厂商起步早,linux堡垒机开发、搭建、部署等技术都已经非常成熟了。
2156 0
|
4月前
|
存储 缓存 负载均衡
CP(强制一致性),AP(最终一致)
本文探讨RPC框架中的服务发现机制,对比DNS、ZooKeeper等方案,指出其在超大规模集群下的局限性。重点提出基于消息总线的最终一致性注册中心,通过AP模型替代CP,提升系统性能与稳定性,适用于高并发、大规模服务节点场景。
CP(强制一致性),AP(最终一致)
|
4月前
|
网络协议 算法 前端开发
07 | 架构设计:设计一个灵活的 RPC 框架
本文深入讲解如何设计一个灵活的 RPC 框架,从基础通信原理出发,剖析传输、协议、服务发现、连接管理等核心模块,并提出分层架构与插件化设计思想,提升系统可扩展性与维护性,助力构建高性能、易演进的分布式服务架构。
|
4月前
|
Java Shell Maven
06-nexus私仓环境搭建
本文介绍Nexus私有仓库环境搭建全过程,包括JDK安装、Nexus OSS版下载与解压、配置文件修改、创建nexus用户并启动服务。详细说明了如何通过Web界面登录、修改默认密码、配置匿名访问,并创建Maven私仓。同时提供上传本地jar包的两种方式,重点演示使用脚本批量导入本地仓库依赖的方法,包含清理无效文件、重命名元数据及执行上传命令等步骤,适用于企业内网构建Maven私服场景。
|
4月前
|
缓存 Ubuntu Linux
Docker安装
本文介绍Docker在CentOS和Ubuntu系统中的安装与配置方法,涵盖卸载旧版本、配置yum源、在线/离线安装、启动服务、设置开机自启、运行HelloWorld测试及daemon.json配置详解,并提供阿里云镜像加速、日志管理、命令补全等实用操作步骤。
|
4月前
|
Java Maven 数据安全/隐私保护
Nexus仓库
Nexus仓库是Sonatype推出的开源制品管理工具,支持Maven、Npm、Docker等格式。本文介绍其在Linux和Docker环境下的安装配置,包括JDK部署、OSS版下载、用户权限、匿名访问设置,以及仓库创建与上传下载操作,涵盖密码重置、数据持久化及脚本批量导入等内容,助力搭建高效私有仓库。
|
3月前
|
传感器 安全 机器人
2026年移动机器人技术架构与选型方法论
随着AI技术发展,移动机器人广泛应用于物流、制造、服务、医疗等领域。本文从技术架构、性能指标、场景适配出发,系统梳理选型方法论,涵盖导航精度、交互能力、续航负载等核心参数,结合仓储搬运、柔性装配、商业接待、医疗康养四大场景需求,提出“五步决策法”,助力科学选型。
|
3月前
|
监控 Windows
Windows笔记本打游戏卡顿掉帧?一招教你解决!
笔记本玩游戏卡顿?可能是显卡设置出了问题。本文分享如何通过NVIDIA控制面板强制使用高性能显卡,轻松将《原神》《星穹铁道》帧率稳定至60FPS,提升游戏体验。排查思路清晰,操作简单,值得一试。
1047 0
|
5月前
|
存储 Web App开发 监控
服装网 item_search 接口对接全攻略:从入门到精通
本文详解服装网商品搜索接口(item_search)的技术实现,涵盖多维度筛选、反爬对抗与数据解析,助你构建稳定高效的时尚商品采集系统,支持选品、趋势分析与比价应用。
|
存储 数据可视化 测试技术
一个测试工程师的实战笔记:我是如何在Postman和Apipost之间做出选择的?
优秀的API测试工具应该具备: 分层设计:既有可视化操作,也开放代码层深度定制 场景感知:自动识别加密需求推荐处理方案 协议包容:不强迫开发者为了不同协议切换工具 数据主权:允许自主选择数据存储位置
417 7

热门文章

最新文章

下一篇
开通oss服务