【分布式微服务云原生】Dockerfile命令详解

Dockerfile 是一个文本文件,它包含了一系列的指令,用于构建一个 Docker 镜像。下面是 Dockerfile 中常用命令的详细解释和示例。

1. 获取镜像的三种方式

通过命令拉取镜像

bash 复制代码
docker pull 镜像名称

从镜像仓库拉取指定的镜像。

通过容器创建镜像

bash 复制代码
docker commit 容器id 镜像名称

从已存在的容器创建一个新的镜像。

通过Dockerfile构建镜像

编写 Dockerfile 文件来自定义和构建镜像。

流程图:获取镜像的三种方式
开始 docker pull 镜像名称 从仓库拉取镜像 开始 docker commit 容器id 镜像名称 从容器创建镜像 开始 编写Dockerfile 构建自定义镜像

2. Dockerfile基础指令

FROM

定义基础镜像信息。

dockerfile 复制代码
FROM nginx

MAINTAINER

作者维护者信息。

dockerfile 复制代码
MAINTAINER 作者名 <邮箱>

RUN

运行Linux命令,制作镜像操作指令。

dockerfile 复制代码
RUN echo '<meta charset=utf8>佳哥带你用docker运行nginx服务' > /usr/share/nginx/html/index.html

ADD

添加文件到容器内,支持自动解压和远程文件下载。

dockerfile 复制代码
ADD 文件路径 /容器内路径

COPY

复制本地文件到容器内,不自动解压。

dockerfile 复制代码
COPY 文件路径 /容器内路径

WORKDIR

设置工作目录。

dockerfile 复制代码
WORKDIR /etc/mysql

USER

切换执行用户。

dockerfile 复制代码
USER root
USER test

VOLUME

定义挂载卷。

dockerfile 复制代码
VOLUME /data

EXPOSE

指定对外的端口。

dockerfile 复制代码
EXPOSE 80

CMD

指定容器启动时要执行的命令。

dockerfile 复制代码
CMD ["nginx", "-g", "daemon off;"]

ENTRYPOINT

指定容器启动时要执行的程序及参数。

dockerfile 复制代码
ENTRYPOINT ["nginx", "-g", "daemon off;"]

ENV

设置环境变量。

dockerfile 复制代码
ENV NAME value

ARG

构建时设置变量。

dockerfile 复制代码
ARG NAME=value

流程图:Dockerfile基础指令
FROM 定义基础镜像 MAINTAINER 定义维护者信息 RUN 执行命令 ADD 添加文件/目录 COPY 复制文件/目录 WORKDIR 设置工作目录 USER 切换用户 VOLUME 定义挂载卷 EXPOSE 暴露端口 CMD 指定启动命令 ENTRYPOINT 指定启动程序 ENV 设置环境变量 ARG 构建时设置变量

3. Dockerfile构建示例

构建Docker镜像

bash 复制代码
docker build --no-cache -t 'jiage3122/my_flask_web' .

打标签

bash 复制代码
docker tag 镜像id 镜像名称

运行容器

bash 复制代码
docker run -d -p 80:80 my-nginx

流程图:Dockerfile构建示例
编写Dockerfile docker build 构建镜像 docker tag 打标签 docker run 运行容器

内容汇总表格
章节 命令 说明
获取镜像 docker pull 从仓库拉取镜像
获取镜像 docker commit 从容器创建镜像
获取镜像 编写Dockerfile 通过Dockerfile构建镜像
基础指令 FROM 定义基础镜像
基础指令 MAINTAINER 定义维护者信息
基础指令 RUN 执行命令
基础指令 ADD 添加文件/目录
基础指令 COPY 复制文件/目录
基础指令 WORKDIR 设置工作目录
基础指令 USER 切换用户
基础指令 VOLUME 定义挂载卷
基础指令 EXPOSE 暴露端口
基础指令 CMD 指定启动命令
基础指令 ENTRYPOINT 指定启动程序
基础指令 ENV 设置环境变量
基础指令 ARG 构建时设置变量
构建示例 docker build 构建Docker镜像
构建示例 docker tag 打标签
构建示例 docker run 运行容器
相关推荐
java修仙传9 分钟前
从手写 Redis 锁到 Redisson:我对分布式锁安全性的理解
java·数据库·redis·分布式
juniperhan3 小时前
Flink 系列第10篇:Flink 分布式缓存详解
分布式·缓存·flink
gihigo19985 小时前
分布式发电的配电网有功-无功综合优化 MATLAB 实现
开发语言·分布式·matlab
立莹Sir5 小时前
SaaS多租户资源隔离的云原生解决方案:在不单独部署的情况下实现租户级资源保障
云原生
脑子加油站5 小时前
OpenEuler24.03 分布式配置redis 集群
数据库·redis·分布式·php·nginx代理
codeejun6 小时前
每日一Go-50、Go微服务--配置中心
开发语言·微服务·golang
程序员老邢6 小时前
【技术底稿 14】通用文件存储组件:SpringBoot 自动装配 + 多存储适配
java·spring boot·后端·阿里云·微服务·策略模式
人道领域6 小时前
GPT-5架构泄露?Kubernetes 1.31发布与Rust重构浪潮下的云原生之变
gpt·云原生·架构
刘~浪地球6 小时前
云原生与容器--Service Mesh (Istio) 入门实战
云原生·istio·service_mesh
想你依然心痛7 小时前
HarmonyOS 5.0工业物联网开发实战:构建分布式智能制造监控与数字孪生预测维护系统
分布式·物联网·harmonyos·数字孪生