从Dockerfile 构建docker镜像——保姆级教程

从Dockfile开始

dockerfile简介
开始构建
1、编辑dockerfile
复制代码
# 使用官方的 Python 3.8 镜像作为基础镜像
FROM python:3.8-slim

# 设置工作目录
WORKDIR /app

# 将当前目录下的所有文件复制到容器的 /app 目录
COPY . /app

# 安装依赖
RUN pip install --no-cache-dir -r requirements.txt

# 暴露端口
EXPOSE 80

# 定义环境变量
ENV NAME World

# 运行应用程序
CMD ["python", "app.py"]
2、构建镜像
复制代码
docker build -t my-python-app .
3、拉取镜像
复制代码
docker pull ubunu

#查看是否拉取成功
docker images
4、推送到镜像仓库
复制代码
docker login   #需要先注册镜像仓库的账号
docker tag my-python-app username/my-python-app
docker push username/my-python-app

Docker 镜像由多个层组成,每一层代表 Dockerfile 中的一个指令。这种分层结构使得镜像的构建和分发更加高效,因为只有发生变化的层需要重新构建或传输。

镜像的优化

为了减少镜像的大小,可以采取以下措施:

1、优化的基本原则
复制代码
使用更小的基础镜像(如 alpine 版本)。
合并多个 RUN 指令以减少层数。
使用 .dockerignore 文件排除不必要的文件。
2、多阶段构建

多阶段构建是一种优化镜像大小的技术,允许在构建过程中使用多个临时镜像,最终只保留必要的文件和层。以下是一个多阶段构建的示例:

复制代码
# 第一阶段:构建应用程序
FROM golang:1.16 AS builder
WORKDIR /app
COPY . .
RUN go build -o myapp .

# 第二阶段:运行应用程序
FROM alpine:latest
WORKDIR /root/
COPY --from=builder /app/myapp .
CMD ["./myapp"]
相关推荐
九章云极AladdinEdu35 分钟前
Kubernetes设备插件开发实战:实现GPU拓扑感知调度
人工智能·机器学习·云原生·容器·kubernetes·迁移学习·gpu算力
泡沫冰@36 分钟前
K8S集群管理(4)
云原生·容器·kubernetes
蒋星熠36 分钟前
深入 Kubernetes:从零到生产的工程实践与原理洞察
人工智能·spring boot·微服务·云原生·容器·架构·kubernetes
泡沫冰@2 小时前
K8S集群管理(2)
云原生·容器·kubernetes
敲上瘾2 小时前
Docker 存储卷(Volume)核心概念、类型与操作指南
linux·服务器·数据库·docker·容器·架构
IT利刃出鞘3 小时前
Docker--宿主机和容器相互拷贝文件
运维·docker·容器
学Linux的语莫5 小时前
kubekey离线搭建k8s高版本>23安装,cri-dockerd通信
云原生·容器·kubernetes
慕容晓开13 小时前
docker,本地目录挂载
docker
Mr. Cao code15 小时前
Docker:颠覆传统虚拟化的轻量级革命
linux·运维·ubuntu·docker·容器
Dontla15 小时前
Docker多共享网络配置策略(Docker多网络、Docker networks、Docker Compose网络、Docker网络、Docker共享网络)
网络·docker·容器