【分布式微服务云原生】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 运行容器
相关推荐
yx9o1 小时前
Kafka 源码 KRaft 模式本地运行
分布式·kafka
Gemini19952 小时前
分布式和微服务的区别
分布式·微服务·架构
G丶AEOM2 小时前
分布式——BASE理论
java·分布式·八股
昌sit!7 小时前
K8S node节点没有相应的pod镜像运行故障处理办法
云原生·容器·kubernetes
P.H. Infinity8 小时前
【RabbitMQ】03-交换机
分布式·rabbitmq
龙哥·三年风水10 小时前
群控系统服务端开发模式-应用开发-个人资料
分布式·php·群控系统
茶馆大橘10 小时前
微服务系列五:避免雪崩问题的限流、隔离、熔断措施
java·jmeter·spring cloud·微服务·云原生·架构·sentinel
北漂IT民工_程序员_ZG11 小时前
k8s集群安装(minikube)
云原生·容器·kubernetes
coding侠客11 小时前
揭秘!微服务架构下,Apollo 配置中心凭啥扮演关键角色?
微服务·云原生·架构
funnyZpC12 小时前
quartz集群增强版🎉
java·分布式·开源·集群·定时任务