Dockerfile(3) - WORKDIR 指令详解

WORKDIR

  • 切换到镜像中的指定路径,设置工作目录
  • 在 WORKDIR 中需要使用绝对路径,如果镜像中对应的路径不存在,会自动创建此目录
  • 一般用 WORKDIR 来替代 切换目录进行操作的指令

RUN cd <path> && <do something>

  • WORKDIR 指令为 Dockerfile 中跟随它的任何 RUN、CMD、ENTRYPOINT、COPY、ADD 指令设置工作目录
  • 如果 WORKDIR 不存在,即使它没有在任何后续 Dockerfile 指令中使用,它也会被创建

小栗子

会将宿主机的 test.txt 文件复制到 镜像的 /tmp/test.txt

复制代码
WORKDIR /tmp
COPY test.txt .

使用相对路径的场景

WORKDIR 指令可以在 Dockerfile 中多次使用

如果提供了相对路径,它将相对于前一个 WORKDIR 指令的路径

python 复制代码
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd

pwd 的输出将会是 /a/b/c

推荐

为了避免出错,推荐WORKDIR指令中只使用绝对路径

使用环境变量

WORKDIR 指令可以使用前面 ENV 设置的环境变量

python 复制代码
ENV DIRPATH=/path
WORKDIR $DIRPATH/$DIRNAME
RUN pwd    # /path/$DIRNAME

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
用户5009376839039几秒前
使用无头浏览器Playwright解决Web打印生成PDF的问题
前端
uhakadotcom1 分钟前
开源一个AI导航站工具-jobleap4u
前端·面试·github
阿聪_2 分钟前
tsconfig.json strict属性配置false会有什么响
前端
艾小码2 分钟前
React Hooks时代:抛弃Class,拥抱函数式组件与状态管理
前端·javascript·react.js
用户50093768390392 分钟前
前端无预览静默打印实现:web-print-pdf npm包与打印专家的完美协作
前端
wycode3 分钟前
Vue2实践(1)之用Vue.extend做一个函数调用的Dialog
前端·vue.js
鹏多多4 分钟前
js使用History.replaceState实现不刷新修改浏览器url
前端·javascript·浏览器
AliciaIr4 分钟前
深入理解CSS居中:面试必备的布局技巧与底层原理(下)
前端·css
晴空雨4 分钟前
关于箭头函数和 ES6 的继承与 ES5 组合寄生式继承的区别
javascript
今禾6 分钟前
JavaScript 响应式系统深度解析:从 `Object.defineProperty` 到 `Proxy` 的演进与优化
前端·javascript·面试