docker 介绍

Docker 介绍

Docker 定义: Docker是一个开源的​​应用容器引擎​​,基于Go语言开发,旨在通过容器化技术解决环境不一致问题。它将应用程序及其依赖(如代码、库、配置文件等)打包到一个轻量级、可移植的容器中,实现"一次构建,到处运行"(Build Once, Run Anywhere)。

**​​核心目标​​:**标准化应用交付流程,消除开发、测试、生产环境差异,提升开发与运维效率。

Docker 优缺点

优点:

1.快速部署

运行时的性能快,管理操作(启动,停止,开始,重启等等)都是以秒或毫秒为单位的。

2.敏捷

像虚拟机一样敏捷,而且会更便宜,在baremeta1(裸机)上布署像点个按钮一样简单。

3.灵活

将应用和系统"容器化",不添加额外的操作系统。

4.轻量级

在一台服务器上可以布署100~1000个Containers 容器。

5.开源免费

开源的,免费的,低成本的。

缺点:

1.安全风险

所有容器共享 linux kernel 资源,资源能否实现最大限制利用,所以在安全上也会存在漏洞。

2.性能问题

I/O 和网络性能略低于裸机。

K8S 弃用Docker的原因

K8S 版本与其使用的容器运行时:

  • k8s 1.24 版本之前用docker作容器运行时
  • k8s 1.24版本和1.24之后的版本后使用containerd作容器运行时

Docker 与 Containerd 的关系

1.Containerd 是 Docker 的核心组件

  • 自 Docker 1.11版本后,Docker将容器运行时功能剥离为独立的 Containerd 项目,作为其底层引擎,负责容器的生命周期管理。
  • 架构层级:docker 的完整调用链为 Docker CLI > Docker Daemon > Container > runC,其中Containerd 承担实际容器操作,Docker 提供高层封装(如镜像构建、网络管理)

2.Containerd 的独立性

2017 年,Containerd 被捐赠给云原生计算基金会(CNCF),成为独立项目,但仍与 Docker 兼容。它可直接被 Kubernetes 等编排系统调用,无需依赖 Docker Daemon。

Containerd 取代 Docker 的原因

1.K8S的生态适配

简化调用链:K8S通过CRI(容器运行时接口)直接调用Containerd,无需经过Docker Daemon、 dockershim适配层,减少调用链,可减少性能损耗和维护成本。

2.性能与资源效率

性能优化:Containerd 比Docker 更加轻量级,启动容器更快、占用资源更少。

3.云原生趋势

职责分离:云原生提倡模块化,Containerd 专注容器运行时,而Docker用于镜像构建。

相关推荐
忆~遂愿26 分钟前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
说实话起个名字真难啊1 小时前
用docker来安装openclaw
docker·ai·容器
恬静的小魔龙2 小时前
【群晖Nas】群晖Nas中实现SVN Server功能、Docker/ContainerManager等
docker·svn·容器
Zfox_2 小时前
CANN Catlass 算子模板库深度解析:高性能 GEMM 融合计算、Cube Unit Tiling 机制与编程范式实践
docker·云原生·容器·eureka
春日见3 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡3 小时前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
liu****4 小时前
2.深入浅出理解虚拟化与容器化(含Docker实操全解析)
运维·c++·docker·容器·虚拟化技术
logocode_li5 小时前
OCI/CRI 双标准下:从 dockerd 到 containerd 的 K8s 运行时迭代史
docker·云原生·容器·k8s
_运维那些事儿17 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
lpruoyu19 小时前
【Docker进阶-05】Docker网络
网络·docker·容器