【docker知识】DockerFile语法 1:注释指令、解释器指令
一、说明
在docker的指令下工作,似乎很简单,然而,对于复杂工程,这些初级知识是不够的。正确使用DockerFile构建镜像是必须的技能。我们这里假定您已经熟练docker的指令,我们继续上升一个台阶,如何用build和dockerfile生成镜像。
二、DockerFile脚本的基本原则
- 该指令不区分大小写。然而,约定是它们是大写的,以便更容易地将它们与参数区分开来。
- Docker 按顺序运行 Dockerfile 中的指令。不存在分支语句。
- Dockerfile 必须以 FROM 指令开头。这可能在解析器指令、注释和全局范围的 ARG 之后。
- 通过一个或多个 ARG 指令,这些指令声明在 FROM 行中使用的参数文件。
- Docker 将以 # 开头的行视为注释,除非该行是有效的解析器指令。
- 行中其他任何位置的 # 标记都被视为参数。
# Comment
RUN echo 'we are running some # of cool things'
三、注释语句语法规则
3.1 编译中注释行视为无有
在执行 Dockerfile 指令之前,有一个语法扫描,在此过程中删除了注释行,这意味着以下示例中的注释不是由执行 echo 命令的 shell 处理的,下面两个示例是等效的:
| RUN echo hello \ # comment world | RUN echo hello \ world |
3.2 在注释语句不能续行
注释中不支持行续行字符“\”。比如下列语句中:
| # this is an example | 合理语法 |
| # this is an \ example | 续行符号无效 |
四、关于空格
4.1 空格出现在语句前
为了向后兼容,注释 (#) 和指令(如 RUN)之前的前导空格被忽略,但不鼓励这种空格行为。解释器不会保留前导空格,因此以下示例是等效的:
| # this is a comment-line RUN echo hello RUN echo world | # this is a comment-line RUN echo hello RUN echo world |
4.2 指令中间的空格
但是请注意,指令参数中的空格(例如 RUN 之后的命令)会被保留,因此以下示例打印带有指定前导空格的“hello world”:
RUN echo "\hello\world"
五、解析器指令
5.1 语法规则
解释器指令,就是指定语法按照哪种解释器解释。它的语法规则是:
- 解析器指令是可选的,它会影响处理 Dockerfile 中后续行的方式。
- 解析器指令形式为#directive=value。
- 处理完注释、空行或构建器指令后,Docker 不再查找解析器指令。相反,它会将任何格式化为解析器指令的内容视为注释,并且不会尝试验证它是否可能是解析器指令。
- 解析器指令必须位于 Dockerfile 的最顶部。
- 解析器指令不区分大小写。但是,约定是它们是小写的。
- 解析器指令不支持行继续字符。
5.2 以下示例均无效
1)不支持续行符号
| # direc \ tive=value | 解析器指令不支持行继续字符 |
2)出现两次无效
| # directive=value1 FROM ImageName | 解析器指令不支持多条同样语句,否则忽略视为无。 |
3)由于出现在构建器指令之后而被视为注释:
| FROM ImageName # directive=value | 必须出现在脚本第一条语句位置 |
4)由于出现在不是解析器指令的注释之后而被视为注释:
| # About my dockerfile # directive=value FROM ImageName | 理由同上,必须出现在脚本首部。 |
5) 由于未被识别,未知指令被视为注释。
| # unknowndirective=value # knowndirective=value | 单词拼写错误,被视为注释。 |
6)解析器指令中允许使用非换行空格。因此下列格式意义相同。
| #directive=value # directive =value # directive= value # directive = value # dIrEcTiVe=value | 空格被扫描删除,因而左栏语句相同。 |
5.3 支持以下解析器指令
syntaxescape
1) escape转义符号定义
一般转义符号是“\”,但是不同的操作系统可能有独立规定,因此,这里可以指定转义符号。
示例语法:
| # escape=` | 规定转义符号 ` |
| # escape=\ | 规定转义符号 \ |
2) 规定解释器版本
#syntax=docker/dockerfile:1 | 用docker/dockerfile:1的解释器 |
#syntax=docker/dockerfile:1.2 | #syntax=docker/dockerfile:1.2解释器 |
建议:除非不得已,不要用这种解析器指令。
六、结论
注释语句也好,解释器语句也好,都不是dockerfile的核心内容,本篇阐述它们的规则,目的有二,其一是期望在dockerfile开发中,不要犯低级错误,避免发生违规而不自知,带来不必要的麻烦。其二,对指令不熟悉,产生盲目猜测,一旦出点错,就瞎找原因。
(后续内容:DockerFile语法 2:构造指令)
相关文章:
【docker知识】DockerFile语法 1:注释指令、解释器指令
一、说明 在docker的指令下工作,似乎很简单,然而,对于复杂工程,这些初级知识是不够的。正确使用DockerFile构建镜像是必须的技能。我们这里假定您已经熟练docker的指令,我们继续上升一个台阶,如何用build和…...
[失业前端恶补算法]JavaScript leetcode刷题top100(一)
专栏声明:只求用最简单的,容易理解的方法通过,不求优化,不喜勿喷 今天更新五个 easy 难度题目: 两数之和 题面 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的…...
HTTP协议
目录 一、HTTP协议 1.http 2.url url的组成: url的保留字符: 3.http协议格式编辑 ①http request ②http response 4.对request做出响应 5.GET与POST方法 ①GET ②POST 7.HTTP常见Header ①Content-Type:: 数据类型(text/html等)在上文…...
javafx学习教程
1.舞台,场景,布局,控件,回调 2.舞台:窗口,一个舞台一个窗口,舞台有舞台基础属性,舞台监听事件,做一些回调 3.fxml里面可以写 页面的布局,控件,然…...
百度百科创建词条教程合集分享,赶紧收藏起来
每一个企业、品牌、人物、产品想要提升自己的知名度,都要创建一个属于自己的百度百科词条,互联网时代,百度搜索引擎的地位是不可撼动的,每天都有上亿的用户在百度上搜索相关内容,百度百科词条在网络营销中占据着举足轻…...
镜像恒流源电路分析
在改进型差动放大器中,用恒流源取代射极电阻RE,既为差动放大电路设置了合适的静态工作电流,又大大增强了共模负反馈作用,使电路具有了更强的抑制共模信号的能力,且不需要很高的电源电压,所以,恒…...
奥威软件宏昊化工启动BI项目,打造智能制造标杆
近日,中国纺织行业领先企业宏昊化工有限公司成功启动了与奥威签订的BI项目,期望通过BI的建立进一步提升企业数字化经营能力和核心竞争力。 奥威bi数据分析软件 在全球经济形势不明朗,国内外市场竞争加剧叠加疫情反复的情况下,化工…...
GitHub访问问题与FastGithub下载及使用(详细篇)
前言 📜 “ 作者 久绊A ” 专注记录自己所整理的Java、web、sql等,IT技术干货、学习经验、面试资料、刷题记录,以及遇到的问题和解决方案,记录自己成长的点滴 目录 前言 FastGithub的介绍 FastGithub的下载 FastGithub的安装及…...
这个打上实时补丁的Linux内核,大家可以看一下
前言最近看到一个关于实时Linux内核的开源项目,是一个比较牛逼的公司发起的,想推荐给大家。Linux的实时性一直是被很多开发者诟病的,一个分时系统怎么能在工业领域发挥自己的长处呢,我认为研究Linux的实时性是非常有必要的&#x…...
三维形体的表面积
三维形体的表面积 在 N * N 的网格上,我们放置一些 1 * 1 * 1 的立方体。 每个值 v grid[i][j] 表示 v 个正方体叠放在对应单元格 (i, j) 上。 请你返回最终形体的表面积。 例子: 输入:[[2,1],[1,0]]输出:18 解题思路࿱…...
二维码数据压缩实践 | 使用python对二维码数据进行压缩 |不乱码,支持中文
当前二维码的应用越来越广泛,包括疫情时期的健康码也是应用二维码的典型案例,最近需要通过一张二维码显示较多文本数据,也就是对二维码数据进行压缩,使用CSDN搜索了半天居然没有能简单使用的代码,很多事例代码解决不了…...
C语言学习_DAY_3_基本数据类型_运算符与表达式【C语言学习笔记】
目录 I. 基本数据类型 II. 复杂的输出和输入语句编写 III. 运算符与表达式 III.I 算术运算符 III.II 关系运算符 III.III 逻辑运算符 III.IV 位运算符 III.V 三目运算符 III.VI 逗号运算符 高质量博主,点个关注不迷路🌸🌸dz…...
c++练习题(4)
题号:1 设int a3,b2;则a*b的结果是() A、2 B、7 C、3 D、8 题号:2 一个程序单位中不包括以下哪项() A、伪代码 B、函数 C、预处理指令 D、全局声明 题号:3 若a-14,…...
腾讯云 cos 字体在CDN上跨域处理
问题描述:项目中用到了字体的静态资源,把静态资源放到了腾讯云对象存储提供的 COS 上,同时启用它的CDN来加速。但是,调试的过程中发现报错:CSS加载字体跨域了,字体图标无法正常显示。 原因:字体…...
api是什么意思?又该如何使用呢?
一、应用程序编程接口 API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件的以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。 API全称 "…...
JavaScript------面向对象
目录 一、面向对象编程(OOP) 基本概念 二、类 1、语法 2、通过类创建对象 3、类的属性 4、类的方法 5、构造函数 三、面向对象的三个特点 1、封装 如何确保数据的安全(实现封装的方式): 2、继承 在子类中&a…...
charles+夜神模拟器抓包
1.资料地址: 链接:https://pan.baidu.com/s/1w9qYfFPJcduN4If50ICccw 提取码:a7xa2.安装charles 和夜神模拟器并配置参考地址: https://www.beierblog.com/archives/%E4%BA%B2%E6%B5%8B%E5%AE%8C%E5%85%A8%E5%8F%AF%E8%A1%8Ccharles%E6%8A%93%E5%8C%85%E…...
【STC15单片机】模拟I2C操作AT24C02数据读取【更新中】
目录 I2C时序结构 I2C代码 AT24C02代码(继承I2C底层代码) PCF8591 PCB上线的长短可能影响数据传输的时间,写I2C时序可能就要加一点延时 I2C时序结构 起始条件:SCL高电平期间,SDA从高电平切换到低电平终止条件&…...
Hadoop
Hadoop Hadoop1.x 2.x 3.x区别 Hadoop1.x组成:MapReduce负责计算和资源调度,HDFS负责数据存储,Common辅助工具。 Hadoop2.x组成:MapReduce负责计算,Yarn负责资源调度,HDFS负责数据存储,Commo…...
ArrayList源码+扩容机制分析
1. ArrayList 简介 ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增长。在添加大量元素前,应用程序可以使用ensureCapacity操作来增加 ArrayList 实例的容量。这可以减少递增式再分配的数量。 ArrayLis…...
5分钟掌握Translumo:Windows平台终极屏幕实时翻译神器
5分钟掌握Translumo:Windows平台终极屏幕实时翻译神器 【免费下载链接】Translumo Advanced real-time screen translator for games, hardcoded subtitles in videos, static text and etc. 项目地址: https://gitcode.com/gh_mirrors/tr/Translumo 想要瞬间…...
WindowResizer完整指南:如何强制调整任意Windows窗口大小
WindowResizer完整指南:如何强制调整任意Windows窗口大小 【免费下载链接】WindowResizer 一个可以强制调整应用程序窗口大小的工具 项目地址: https://gitcode.com/gh_mirrors/wi/WindowResizer 还在为那些无法调整大小的Windows窗口而烦恼吗?老…...
2025最权威的AI辅助论文方案解析与推荐
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 全方位提升文本致然度和原创性是降低AIGC率的关键所在,第一步,杜绝直…...
如何3步掌握图表数据提取:WebPlotDigitizer让科研数据重获新生
如何3步掌握图表数据提取:WebPlotDigitizer让科研数据重获新生 【免费下载链接】WebPlotDigitizer Computer vision assisted tool to extract numerical data from plot images. 项目地址: https://gitcode.com/gh_mirrors/we/WebPlotDigitizer 你是否曾面对…...
Adobe-GenP终极指南:如何免费激活Adobe全家桶的完整教程
Adobe-GenP终极指南:如何免费激活Adobe全家桶的完整教程 【免费下载链接】Adobe-GenP Adobe CC 2019/2020/2021/2022/2023 GenP Universal Patch 3.0 项目地址: https://gitcode.com/gh_mirrors/ad/Adobe-GenP Adobe-GenP是一款专门针对Adobe Creative Cloud…...
LibreDWG:解放AutoCAD文件的瑞士军刀,3个实用场景教你玩转开源CAD处理
LibreDWG:解放AutoCAD文件的瑞士军刀,3个实用场景教你玩转开源CAD处理 【免费下载链接】libredwg Official mirror of libredwg. With CI hooks and nightly releases. PRs ok 项目地址: https://gitcode.com/gh_mirrors/li/libredwg 还在为无法打…...
基于机器学习的胃肠道出血检测:从特征工程到深度学习模型实战
1. 项目概述:当AI遇见肠道“侦察兵”在消化内科的日常工作中,医生们常常面临一个耗时且费力的挑战:审阅由无线胶囊内镜(VCE)拍摄的数万张肠道图像,以寻找那可能仅占几帧的出血病灶。这无异于大海捞针&#…...
5分钟彻底告别乱码!GBKtoUTF-8编码转换终极指南
5分钟彻底告别乱码!GBKtoUTF-8编码转换终极指南 【免费下载链接】GBKtoUTF-8 To transcode text files from GBK to UTF-8 项目地址: https://gitcode.com/gh_mirrors/gb/GBKtoUTF-8 还在为Windows和Mac之间文件传输乱码而烦恼吗?GBKtoUTF-8编码转…...
AD19中3D封装高度偏移设置,精准解决PCB叠层元件DRC干涉警告
1. 为什么PCB叠层元件会触发DRC高度干涉警告 当我们在Altium Designer 19中进行多层PCB设计时,经常会遇到主板和子板叠放的情况。比如你可能需要在主板上方通过螺柱固定一块功能子板,两者之间保留10mm的间隙。这时候如果在间隙区域放置元件,A…...
3个隐藏技巧:让你的PS4手柄在PC上比Xbox手柄更好用
3个隐藏技巧:让你的PS4手柄在PC上比Xbox手柄更好用 【免费下载链接】DS4Windows Like those other ds4tools, but sexier 项目地址: https://gitcode.com/gh_mirrors/ds/DS4Windows 还在为PS4手柄连接Windows电脑后的兼容性发愁吗?是不是每次打开…...
