RUN命令是在Docker镜像构建过程中执行命令的指令,用于安装软件、配置环境等操作。它通过创建新层将更改固化到镜像中,确保软件持久化。语法分shell模式(如RUN apt-get update)和exec模式(如RUN ["apt-get", "install", "-y", "curl"]),推荐合并多条命令以减少层数、清理缓存以减小体积,并避免存储敏感信息,从而提升镜像的安全性与效率。
在Docker容器中安装软件,最常见也最标准的方式是在构建镜像时通过 Dockerfile 中的 RUN 指令完成。这种方式可以将所需软件永久固化到镜像中,便于复用和部署。
语法格式如下:
RUN# shell模式,默认使用 /bin/sh -c RUN ["executable", "param1", "param2"] # exec模式
例如,在基于Ubuntu的镜像中安装curl:
RUN apt-get update && apt-get install -y curl
常用操作包括:
完整示例:构建一个带curl和net-tools的基础Ubuntu镜像
FROM ubuntu:20.04RUN apt-get update \ && apt-get install -y curl net-tools \ && rm -rf /var/lib/apt/lists/*
说明:
RUN echo "Hello" > /tmp/hello.txt这条命令会被包装成:
/bin/sh -c 'echo "Hello" > /tmp/hello.txt'
2. Exec模式
RUN ["apt-get", "install", "-y", "curl"]这种形式不经过she
ll,适合需要精确控制执行环境的场景,比如指定不同的解释器。示例:合并安装与清理
RUN apt-get update \
&& apt-get install -y \
nginx \
python3 \
python3-pip \
&& pip3 install flask \
&& rm -rf /var/lib/apt/lists/* /root/.cache基本上就这些。只要理解RUN是在构建阶段执行命令,并把结果保存进镜像,就能正确使用它来安装软件。关键是要写好Dockerfile,让镜像轻量、安全、可维护。