CRI 作为 Kubernetes 和容器运行时之间的桥梁,定义了一组标准的 gRPC 调用,Kubernetes 使用这些调用与容器进行交互。这个抽象层使我们可以在不影响 Kubernetes 的情况下,将 Docker 替换为其他运行时。

CRI-O:精简高效的容器机器

在我们的 Docker 替代方案中,首先介绍的是 CRI-O。它是由 Red Hat、Intel、SUSE 和 IBM 共同努力的产物,就像那个总是做得很好的表亲。

为什么选择 CRI-O?

  • 轻量级,专为 Kubernetes 设计
  • 符合 OCI 标准(开放容器倡议)
  • 支持多种镜像格式
  • 强调安全性和稳定性

开始使用 CRI-O

让我们动手设置一个使用 CRI-O 的 Kubernetes 集群。首先,我们需要在节点上安装 CRI-O:


# 设置操作系统发行版
OS=xUbuntu_20.04

# 设置 CRI-O 版本
VERSION=1.23

# 添加 CRI-O 仓库
echo "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/$OS/ /" > /etc/apt/sources.list.d/devel:kubic:libcontainers:stable.list
echo "deb http://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable:/cri-o:/$VERSION/$OS/ /" > /etc/apt/sources.list.d/devel:kubic:libcontainers:stable:cri-o:$VERSION.list

# 导入 GPG 密钥
curl -L https://download.opensuse.org/repositories/devel:kubic:libcontainers:stable:cri-o:$VERSION/$OS/Release.key | apt-key add -
curl -L https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/$OS/Release.key | apt-key add -

# 更新并安装 CRI-O
apt-get update
apt-get install cri-o cri-o-runc

现在我们已经安装了 CRI-O,让我们配置 Kubernetes 使用它。在使用 kubeadm 初始化 Kubernetes 集群时,使用以下命令:


kubeadm init --cri-socket=/var/run/crio/crio.sock

就这样!你现在正在使用 CRI-O 运行 Kubernetes。那么它与 Docker 相比表现如何呢?

性能比较

在我们的测试中,我们发现 CRI-O 在容器启动时间和资源利用率方面通常优于 Docker。以下是一个快速的对比:

指标 Docker CRI-O
容器启动时间 300ms 250ms
内存使用(空闲) 50MB 30MB
CPU 使用(空闲) 0.5% 0.3%

这些数字看起来可能很小,但在大规模部署中,它们的影响可能会显著增加。

containerd:默默无闻的工作马

接下来是 containerd,这个运行时多年来一直在默默支持 Docker。它就像你车里的引擎——你可能不常想到它,但它在做所有的重活。

为什么选择 containerd?

  • 在生产环境中经过实战考验
  • 模块化且可扩展
  • 强大的社区支持
  • 主要云提供商的原生支持

设置 containerd

让我们使用 containerd 设置一个 Kubernetes 集群。首先,我们需要安装它:


# 安装 containerd
apt-get update && apt-get install -y containerd

# 配置 containerd 并启动服务
mkdir -p /etc/containerd
containerd config default > /etc/containerd/config.toml
systemctl restart containerd

现在,让我们使用 containerd 初始化我们的 Kubernetes 集群:


kubeadm init --cri-socket=/run/containerd/containerd.sock

兼容性考虑

虽然 containerd 通常与 Docker 非常兼容,但有几点需要注意:

  • Docker 特定的命令不能直接在 containerd 上使用
  • 某些 Docker 特定的功能(如 Docker Compose)可能需要替代方案
  • 镜像构建可能需要不同的工具(如 buildah 或 kaniko)

房间里的大象(或鲸鱼):Docker 怎么样?

你可能会想,“如果这些替代方案如此出色,为什么 Docker 曾经是首选?” 其实,Docker 做了很多正确的事情:

  • 它让容器变得易于访问和使用
  • 它提供了一个全面的生态系统(Docker Hub、Docker Compose 等)
  • 它拥有(并且仍然拥有)庞大的社区和丰富的资源

但随着 Kubernetes 的流行和成熟,对更专业、更轻量级的运行时的需求变得明显。这就是 CRI-O 和 containerd 发挥作用的地方。

切换:挑战与解决方案

从 Docker 过渡到替代运行时并非没有挑战。以下是一些常见的障碍及其解决方法:

1. 镜像兼容性

挑战:某些 Docker 镜像可能无法直接与替代运行时一起使用。

解决方案:使用符合 OCI 标准的镜像和工具,如 Buildah 或 Kaniko 进行镜像构建。

2. 开发者工作流程

挑战:习惯于 Docker CLI 的开发者可能会在过渡中遇到困难。

解决方案:引入像 Podman 这样的工具,它在使用 CRI-O 或 containerd 时提供类似 Docker 的 CLI 体验。

3. 监控和日志记录

挑战:现有的监控解决方案可能与 Docker 紧密耦合。

解决方案:利用 Kubernetes 原生的监控解决方案,如 Prometheus 和 Grafana,它们与任何 CRI 兼容的运行时都能很好地配合。

结论:使用 Docker 还是不使用 Docker?

经过我们的实践探索,很明显 CRI-O 和 containerd 都是管理 Kubernetes 集群的可行替代方案。它们提供了更好的性能、更紧密的 Kubernetes 集成和更专注的功能集。

然而,是否切换的决定应基于你的具体用例。如果你正在启动一个新的 Kubernetes 项目,从一开始就选择 CRI-O 或 containerd 可能会为你节省一些麻烦。对于现有的部署,仔细权衡收益与迁移所需的努力。

总结:未来是容器化的(但不一定是 Docker 化的)

正如我们所见,容器运行时的世界正在超越 Docker。CRI-O 和 containerd 提供了引人注目的替代方案,可以提高你的 Kubernetes 集群的性能和效率。

记住,目标不是追逐最新的趋势,而是选择最适合你需求的工具。无论你是坚持使用 Docker 还是转向替代方案,最重要的是继续容器化、编排和创新。

现在,去征服世界吧!(这次可能没有鲸鱼。)

“最好的运行时是你不必去想的。” - 每位 DevOps 工程师,可能

进一步阅读

你在 Kubernetes 集群中从 Docker 切换了吗?在下面的评论中分享你的经验!