Docker03-知识点整理

Docker03-知识点整理

文章目录

1-参考网址


2-知识整理

  • 1)-Docker image和Docker Native image区别->Native不依赖JVM等运行环境,是单独的可执行文件,启动更快!
  • 2)

2-思考题

1-Docker image和Docker Native image有什么区别

问题背景:我在kafka官网进行软件下载的时候,Docker版本有2个可以下载的镜像,地址:https://kafka.apache.org/downloads

1. Docker Image(Docker 镜像)

定义

Docker 镜像是一个只读的模板,它包含了运行容器所需的一切,如代码、运行时环境、系统工具、系统库等。可以将其看作是一个软件包,这个软件包可以被部署到 Docker 环境中运行。

特点
  • 分层结构:Docker 镜像采用分层存储的方式构建,每一层都是一个文件系统的变更。这些层可以被多个镜像共享,从而节省磁盘空间。例如,多个不同的镜像可能都基于同一个基础操作系统层。
  • 通用性:Docker 镜像可以在任何支持 Docker 的环境中运行,具有良好的可移植性。只要目标环境安装了 Docker 引擎,就可以拉取并运行镜像。
  • 构建灵活性:可以通过编写 Dockerfile 来定义镜像的构建过程。Dockerfile 中包含了一系列的指令,如从基础镜像开始、安装软件包、复制文件等,通过执行这些指令可以构建出所需的镜像。
构建和使用示例
Dockerfile 复制代码
# 使用官方的 Python 3.9 镜像作为基础
FROM python:3.9

# 设置工作目录
WORKDIR /app

# 复制当前目录下的所有文件到工作目录
COPY . .

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

# 暴露端口
EXPOSE 8000

# 定义容器启动时执行的命令
CMD ["python", "app.py"]

使用 docker build 命令构建镜像:

bash 复制代码
docker build -t my-python-app .

使用 docker run 命令运行容器:

bash 复制代码
docker run -p 8000:8000 my-python-app

2. Docker Native Image(通常指 GraalVM Native Image 结合 Docker)

定义

GraalVM Native Image 是 GraalVM 提供的一项技术,它可以将 Java 代码编译成独立的可执行文件,这个可执行文件不依赖于 Java 虚拟机(JVM)。当将这种 Native Image 打包成 Docker 镜像时,就形成了 Docker Native Image。

特点
  • 启动速度快:由于 Native Image 不依赖于 JVM 的启动过程,因此启动速度比传统的基于 JVM 的应用程序要快得多。对于需要快速启动和响应的应用场景,如函数计算、微服务等,这是一个非常重要的优势。
  • 内存占用小:Native Image 不需要加载 JVM 所需的大量资源,因此内存占用相对较小。这可以提高资源利用率,降低运营成本。
  • 构建复杂性:构建 Native Image 需要额外的工具和配置,相对传统的 Docker 镜像构建要复杂一些。需要使用 GraalVM 的工具链进行编译,并且可能需要处理一些特定的依赖和配置问题。
构建和使用示例

首先,确保你已经安装了 GraalVM 并配置好了环境变量。然后,在项目中添加 GraalVM Native Image 插件(以 Maven 项目为例):

xml 复制代码
<plugin>
    <groupId>org.graalvm.buildtools</groupId>
    <artifactId>native-maven-plugin</artifactId>
    <version>0.9.22</version>
    <executions>
        <execution>
            <id>build-native</id>
            <goals>
                <goal>compile-no-fork</goal>
            </goals>
        </execution>
    </executions>
</plugin>

使用以下命令编译 Native Image:

bash 复制代码
mvn package -Pnative

编写 Dockerfile 来构建 Docker Native Image:

Dockerfile 复制代码
# 使用一个轻量级的基础镜像
FROM debian:buster-slim

# 复制编译好的 Native Image 到容器中
COPY target/my-native-app /app/my-native-app

# 设置工作目录
WORKDIR /app

# 定义容器启动时执行的命令
CMD ["./my-native-app"]

使用 docker build 命令构建镜像:

bash 复制代码
docker build -t my-native-app .

使用 docker run 命令运行容器:

bash 复制代码
docker run my-native-app

3. 两者的主要区别

  • 运行时依赖:Docker 镜像可以基于各种运行时环境,如 JVM、Python 解释器等;而 Docker Native Image 通常是不依赖于虚拟机或解释器的独立可执行文件。
  • 启动性能:Docker Native Image 的启动速度通常比传统的 Docker 镜像要快,因为它不需要启动虚拟机或解释器。
  • 内存占用:Docker Native Image 的内存占用相对较小,因为它不需要加载虚拟机或解释器所需的大量资源。
  • 构建复杂度 :Docker 镜像的构建相对简单,只需要编写 Dockerfile 并执行 docker build 命令;而 Docker Native Image 的构建需要额外的工具和配置,相对复杂一些。

相关推荐
zml_201515 小时前
docker 1分钟 快速搭建 redis 哨兵集群
linux·redis·docker·docker-compose
草履虫建模16 小时前
若依微服务一键部署(RuoYi-Cloud):Nacos/Redis/MySQL + Gateway + Robot 接入(踩坑与修复全记录)
redis·mysql·docker·微服务·云原生·nacos·持续部署
阿鹿.18 小时前
docker-相关笔记
java·笔记·docker
007php00720 小时前
Go 语言常用命令使用与总结
java·linux·服务器·前端·数据库·docker·容器
你是我的日月星河21 小时前
Docker部署单节点使用KRaft存储数据的Kafka与可视化界面Kafka-Map
docker·容器·kafka
007php00721 小时前
Go Vendor 和 Go Modules:管理和扩展依赖的最佳实践
java·开发语言·docker·微服务·golang·自动化·jenkins
Clownseven1 天前
Jenkins与Docker搭建CI/CD流水线实战指南 (自动化测试与部署)
ci/cd·docker·jenkins
ZLRRLZ1 天前
【Docker/Redis】服务端高并发分布式结构演进之路
redis·docker·架构
搞不懂语言的程序员1 天前
docker 搭建zookper集群,快照虚拟机多机模拟
运维·docker·容器