• 【K8S 九】使用docker作为CRI


    目录

    简介

    安装cri-dockerd

    配置cri-dockerd

    配置kubelet


    简介

    kubernetesdockershim从kubelet中移除了,紧接着docker就宣布和Mirantis合作维护独立于Kubernetes之外的shim代码cri-dockerd,作为Docker引擎API的一致CRI接口。这意味着我们可以像以前一样继续构建基于Docker引擎的Kubernetes环境,只需从内置的dockershim切换到外部的dockershim。

    安装cri-dockerd

    既然是从内置到了外置,那肯定要额外安装了。目前的最新版本是0.2.3,发布了多个主流Linux的二进制安装包,以centos7为例,可以直接下载cri-dockerd-0.2.3-3.el7.x86_64.rpm包进行安装:

    1. sudo rpm -ivh cri-dockerd-0.2.3-3.el7.x86_64.rpm
    2. sudo systemctl daemon-reload
    3. sudo systemctl enable cri-docker.service
    4. sudo systemctl enable --now cri-docker.socket

    看一下该RPM包都包含什么文件(很简单,只有一个二进制可执行文件以及一个service Unix文件、一个socket Unix文件)比较类似于docker目前的启动方式。

    1. rpm -ql cri-dockerd |grep -v share
    2. /usr/bin/cri-dockerd
    3. /usr/lib/systemd/system/cri-docker.service
    4. /usr/lib/systemd/system/cri-docker.socket

    配置cri-dockerd

    可以通过cri-dockerd --help查看支持的参数进行配置。这里要说明的是--pod-infra-container-image的配置,因为kubelet中已经弃用了该参数,直接从cri侧获取sandbox image;docker作为cri则需要在这里进行配置,否则会报错( failed pulling image "k8s.gcr.io/pause:3.6": Error response from daemon: Get "https://k8s.gcr.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers))。

    --network-plugin=cni 如果不指定,pod会使用docker的网络

    ExecStart=/usr/bin/cri-dockerd --container-runtime-endpoint fd:// --network-plugin=cni --pod-infra-container-image=192.168.11.101/kubeadm/pause:3.7 

    另外,还有一个不同点,如果我们的私有镜像仓库pull镜像需要认证,除了使用kubernetes的secret外,可以事先通过docker login成功后,就不会报认证不通过了,但是现在不行了。

    配置kubelet

    --container-runtime-endpoint=unix:///run/cri-dockerd.sock

    1. #KUBELET_KUBEADM_ARGS="--container-runtime=remote --container-runtime-endpoint=unix:///var/run/containerd/containerd.sock --pod-infra-container-image=192.168.11.101/kubeadm/pause:3.7"
    2. KUBELET_KUBEADM_ARGS="--container-runtime=remote --container-runtime-endpoint=unix:///run/cri-dockerd.sock"

    当然kubelet、docker的安装,以及docker的daemon.json配置跟之前一样,就不赘述了。

  • 相关阅读:
    掌握Midjourney视觉艺术的关键提示词指南
    String&StringBuilder&StringBuffer
    IT售前“楠“知识之这!就是售前-尚文网络xUP楠哥
    字符串-算法总结
    再探Handler(下)(Handler核心原理最全解析)
    Spring详解及具体使用
    重塑消费者与商家关系的力量
    如何安装GCC?
    【最强最全车牌识别算法】支持13种中文车牌识别的云端API部署(可直接获取源码使用)
    大模型chatgpt4分析功能初探
  • 原文地址:https://blog.csdn.net/avatar_2009/article/details/126106024