【k8s】(四)kubernetes1.29.4离线部署之-组件安装

devtools/2024/11/14 2:09:46/

(一)kubernetes1.29.4离线部署之-安装文件准备
(二)kubernetes1.29.4离线部署之-镜像文件准备
(三)kubernetes1.29.4离线部署之-环境初始化
(四)kubernetes1.29.4离线部署之-组件安装
(五)kubernetes1.29.4离线部署之-初始化第一个控制平面
(六)kubernetes1.29.4离线部署之-加入Node节点
(七)kubernetes1.29.4离线部署之-网络插件
(八)kubernetes1.29.4离线部署之-测试验证

备注: 完整版请参阅 【k8s】Kubernetes 1.29.4离线安装部署(总)

组件安装

需要安装的组件列表
  1. 安装containerd
  2. 部署containerd 配置文件
  3. 安装cni plugin
  4. 安装crictl
  5. 安装runc
  6. 安装部署kubeadm、kubelet、kubectl

特别关注:
再拷贝kubeadm、kubelet、kubectl文件后,务必记得要创建必须要的几个目录,否则会导致后面初始化控制平面时会出错,详情见完整的安装脚本
sudo mkdir -p /var/lib/kubelet
sudo mkdir -p /etc/kubernetes/manifests
yum 自动从网络安装不会出现该问题,会自动创建。

  1. 初始化集群第一控制平面节点
安装完整的脚本
#!/bin/bash
###############################################
# QingHub K8S Install 版本: $VERSION
# 架构: $ARCH_TYPE 目前版本主要支持amd64,其他待敬请期待
# 操作系统: $os_type
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                           https://qinghub.net
###############################################
ENV_CFG=./env.cfg
if [ -f ${ENV_CFG} ] ; thenchmod 777 ${ENV_CFG}source ${ENV_CFG}
fi
os_type=$(uname -s)if [ $(arch) = "x86_64" ] || [ $(arch) = "amd64" ]; thenarch_type=amd64
elif [ $(arch) = "aarch64" ] || [ $(arch) = "arm64" ]; thenarch_type=arm64
elif [ $(arch) = "i386" ]; thenarch_type=amd64echo -e "${YELLOW}[WAIN] 检测到 i386, 我们暂时把它当做 x86_64(amd64) ${NC}"
elseecho -e "${RED}[ERROR] QingHub Studio 目前还不支持 $(arch) 架构 ${NC}"exit 1
fi###############################################
# 复制并安装cri_containerd_cni 包括:cri, containerd,cni三合一,后续会覆盖安装
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                                https://qinghub.net
###############################################
function install_cri_containerd_cni(){echo -e "${GREEN}[INFO] 下载并安装cri_containerd_cni二级制文件 ${cri_containerd_cni_name} ${NC}"if [[ -e /usr/bin/curl ]]; then# 离线下载文件请修改TODOcurl -L ${cri_containerd_cni_url} | sudo tar -C / -xz || {echo -e "${RED}[ERROR] 下载并安装cri_containerd_cni二进制文件失败 ${NC}"exit 1}elsewget -c "$cri_containerd_cni_url" | sudo tar -C / -xz || {echo -e "${RED}[ERROR] 下载cri_containerd_cni二进制文件失败 ${NC}"exit 1}fiecho -e "${GREEN}[INFO] 创建containerd.service 文件 ${NC}"sudo systemctl enable --now containerdecho -e "${GREEN}[INFO] 安装containerd成功${NC}"
}###############################################
# 描述: 初始化containerd 配置文件,添加修改仓库信息,请酌情修改
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                                https://qinghub.net
###############################################
function install_containerd_config(){mkdir -p /etc/containerdsudo /usr/local/bin/containerd config default | tee /etc/containerd/config.toml# 修改Containerd的配置文件sudo sed -i "s#SystemdCgroup\ \=\ false#SystemdCgroup\ \=\ true#g" /etc/containerd/config.tomlcat /etc/containerd/config.toml | grep SystemdCgroupsudo sed -i "s#registry.k8s.io\/pause:3.8#qinghub.net:5000\/qingcloudtech\/pause:3.9#g" /etc/containerd/config.tomlcat /etc/containerd/config.toml | grep sandbox_imagesudo sed -i "s#config_path\ \=\ \"\"#config_path\ \=\ \"/etc/containerd/certs.d\"#g" /etc/containerd/config.tomlcat /etc/containerd/config.toml | grep certs.dmkdir /etc/containerd/certs.d/qinghub.net:5000 -pvsudo bash -c 'cat > /etc/containerd/certs.d/qinghub.net:5000/hosts.toml << EOF
server = "qinghub.net:5000"
[host."qinghub.net:5000"]capabilities = ["pull", "resolve"]
EOF'mkdir /etc/containerd/certs.d/docker.io -pvsudo bash -c 'cat > /etc/containerd/certs.d/docker.io/hosts.toml << EOF
server = "https://docker.io"
[host."https://qinghub.net:5000"]capabilities = ["pull", "resolve"]
[host."https://dockerproxy.com"]capabilities = ["pull", "resolve"]
[host."https://docker.m.daocloud.io"]capabilities = ["pull", "resolve"]
[host."https://reg-mirror.qiniu.com"]capabilities = ["pull", "resolve"]
[host."http://hub-mirror.c.163.com"]capabilities = ["pull", "resolve"]
EOF'systemctl daemon-reloadsystemctl restart containerd.service
}###############################################
# 描述: 安装cni文件
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                                https://qinghub.net
###############################################
function install_cni_plugins(){DEST="/opt/cni/bin"sudo mkdir -p "$DEST"echo -e "${GREEN}[INFO] 下载并安装cni_plugins二级制文件 ${cni_plugins_name} ${NC}"if [[ -e /usr/bin/curl ]]; then# 离线下载文件请修改TODOcurl -L ${cni_plugins_url} | sudo tar -C "$DEST" -xz || {echo -e "${RED}[ERROR] 下载cni_plugins二进制文件失败 ${NC}"exit 1}elsewget -c "$cni_plugins_url" | sudo tar -C "$DEST" -xz || {echo -e "${RED}[ERROR] 下载cni_plugins二进制文件失败 ${NC}"exit 1}fiecho -e "${GREEN}[INFO] 安装cni_plugins成功${NC}"
}###############################################
# 描述: 拷贝runc文件
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                                https://qinghub.net
###############################################
function install_runc(){DEST="/usr/bin"sudo mkdir -p "$DEST"cd "$DEST"echo -e "${GREEN}[INFO] 下载并安装runc二级制文件 ${runc_name} ${NC}"if [[ -e /usr/bin/curl ]]; then# 离线下载文件请修改TODOcurl -L -O ${runc_url} || {echo -e "${RED}[ERROR] 下载并安装runc二进制文件失败 ${NC}"exit 1}elsewget -c "$runc_url" || {echo -e "${RED}[ERROR] 下载runc二进制文件失败 ${NC}"exit 1}fiif [ -f $DEST/runc.amd64 ]; thenchmod +x $DEST/runc.amd64mv $DEST/runc.amd64 $DEST/runcfiecho -e "${GREEN}[INFO] 安装runc成功${NC}"
}###############################################
# 描述: 拷贝crictl工具文件
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                                https://qinghub.net
###############################################
function install_crictl(){DEST="/usr/local/bin"sudo mkdir -p "$DEST"echo -e "${GREEN}[INFO] 下载并安装crictl二级制文件 ${crictl_name} ${NC}"if [[ -e /usr/bin/curl ]]; then# 离线下载文件请修改TODOsudo curl -L ${crictl_url} | sudo tar -C $DEST -xz || {echo -e "${RED}[ERROR] 下载crictl二进制文件失败 ${NC}"exit 1}elsesudo wget -c "$crictl_url" | sudo tar -C "$DEST" -xz || {echo -e "${RED}[ERROR] 下载crictl二进制文件失败 ${NC}"exit 1}fiecho -e "${GREEN}[INFO] 安装crictl成功${NC}"#生成配置文件sudo bash -c "cat > /etc/crictl.yaml <<EOF
runtime-endpoint: unix:///run/containerd/containerd.sock
image-endpoint: unix:///run/containerd/containerd.sock
timeout: 10
EOF"systemctl restart containerd
}###############################################
# 描述: 安装kubeadmin,kubelet,kubectl,在每个节点都需要安装kubeadmin,kubelet,
# kubectl根据情况在合适的控制平台节点安装,可以修改参数$QINGCLOUD_KUBECTL_FLAG=no关闭安装
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                                https://qinghub.net
###############################################
function install_kubeadm(){TEMP="/tmp"echo -e "${GREEN}[INFO] 下载Kubernetes二级制文件 ${KUBERNETES_VERSION} ${NC}"if [[ -e /usr/bin/curl ]]; then# 离线下载文件请修改TODOsudo curl -L "${kubernetes_server_url}" | sudo tar -C "$TEMP" -xz || {echo -e "${RED}[ERROR] 下载Kubernetes二进制文件失败 ${NC}"exit 1}elsesudo wget -c "$kubernetes_server_url" | sudo tar -C "$TEMP" -xz || {echo -e "${RED}[ERROR] 下载Kubernetes二进制文件失败 ${NC}"exit 1}fiDEST="/usr/bin"cd $DESTsudo cp $TEMP/kubernetes/server/bin/{kubeadm,kubelet} .sudo chmod +x {kubeadm,kubelet}echo -e "${GREEN}[INFO] 成功安装kubeadm,kubelet到${DEST}目录 ${NC}"echo -e "${GREEN}[INFO] 创建kubelet.service 文件 ${NC}"sudo bash -c "cat > /usr/lib/systemd/system/kubelet.service <<EOF
[Unit]
Description=kubelet: The Kubernetes Node Agent
Documentation=https://kubernetes.io/docs/
Wants=network-online.target
After=network-online.target[Service]
ExecStart=${DEST}/kubelet
Restart=always
StartLimitInterval=0
RestartSec=10[Install]
WantedBy=multi-user.target
EOF"sudo mkdir -p /usr/lib/systemd/system/kubelet.service.decho -e "${GREEN}[INFO] 创建10-kubeadm.conf 文件 ${NC}"sudo bash -c "cat > /usr/lib/systemd/system/kubelet.service.d/10-kubeadm.conf <<EOF
[Service]
Environment=\"KUBELET_KUBECONFIG_ARGS=--bootstrap-kubeconfig=/etc/kubernetes/bootstrap-kubelet.conf --kubeconfig=/etc/kubernetes/kubelet.conf\"
Environment=\"KUBELET_CONFIG_ARGS=--config=/var/lib/kubelet/config.yaml\"
EnvironmentFile=-/var/lib/kubelet/kubeadm-flags.env
EnvironmentFile=-/etc/sysconfig/kubelet
ExecStart=
ExecStart=$DEST/kubelet \\\$KUBELET_KUBECONFIG_ARGS \\\$KUBELET_CONFIG_ARGS \\\$KUBELET_KUBEADM_ARGS \\\$KUBELET_EXTRA_ARGS
EOF"
sudo bash -c "cat > /etc/sysconfig/kubelet <<EOF
KUBELET_EXTRA_ARGS=
EOF"#创建必须要的几个目录sudo mkdir -p /var/lib/kubeletsudo mkdir -p /etc/kubernetes/manifestssudo systemctl enable kubeletif [ "$QINGCLOUD_KUBECTL_FLAG" == "yes" ]; thencd $DESTsudo cp ${TEMP}/kubernetes/server/bin/kubectl .sudo chmod +x kubectlecho -e "${GREEN}[INFO] 成功安装kubectl到${DEST}目录 ${NC}"fiif [[ -d "${TEMP}/kubernetes" ]]; thensudo rm -rf "${TEMP}/kubernetes-server-linux-amd64"echo -e "${GREEN}[INFO] 临时安装文件${TEMP}/kubernetes-server-linux-amd64正常删除 ${NC}"fi
}###############################################
# 描述: 初始化控制平面节点。
# ${QINGCLOUD_ADVERTISE_ADDRESS}       ApiServer地址,请根据情况填写,可以是配置的高可用地址
# ${LOCAL_IMAGE_DOMAIN}               本地容器镜像仓库地址
# ${LOCAL_IMAGE_NAMESPACE}            本地容器镜像命名空间
# ${KUBERNETES_VERSION}               K8S版本
# QingHub Studio官网: https://qinghub.net
# 如过您安装遇到问题,请到官网查找官方联系方式或加支持群:
#                                https://qinghub.net
###############################################
function init_cluster(){echo -e "${GREEN}[INFO] ==========初始化第一个控制平面,请根据输出结果初始其他他节点========= ${NC}"kubeadm init \--apiserver-advertise-address="${QINGCLOUD_ADVERTISE_ADDRESS}" \--image-repository "${LOCAL_IMAGE_DOMAIN}/${LOCAL_IMAGE_NAMESPACE}" \--kubernetes-version "${KUBERNETES_VERSION}" \--cri-socket=unix:///run/containerd/containerd.sock \--service-cidr=10.96.0.0/16 \--pod-network-cidr=172.16.0.0/16
}# 主入口地址,根据实际可以手动执行相关内容
function main {echo -e "${GREEN}[INFO] ==========开始安装kubernetes========= ${NC}"#安装containerdinstall_cri_containerd_cni#安装cni plugininstall_cni_plugins#安装containerd 配置文件install_containerd_config#安装crictlinstall_crictl#安装runcinstall_runc#安装kubeadminstall_kubeadm#初始化集群master节点if [ "$QINGCLOUD_KUBECTL_FLAG" == "yes" ] ;theninit_clusterfiecho -e "${GREEN}[INFO] ==========完成安装kubernetes========= ${NC}"
}main

你可以通过【QingHub Studio】) 套件直接安装部署,也可以手动按如下文档操作,该项目已经全面开源,完整的脚本可以从如下开源地址获取:
开源地址: https://gitee.com/qingplus/qingcloud-platform
【QingHub Studio集成开发套件】


http://www.ppmy.cn/devtools/12826.html

相关文章

如何选择适用于Mac的iPhone数据恢复软件?

以下是全球无数 Mac 用户每天遇到的场景&#xff1a; 用户丢失了重要文件。用户在搜索中输入术语“iPhone数据恢复软件”。出现了数百个可能合适的软件应用程序&#xff0c;使用户很难决定其中哪一个是最好的。 这并不好&#xff0c;因为iOS数据恢复是一个时间敏感的过程&…

分类与预测算法评价的介绍

分类与预测算法的评价是在机器学习中至关重要的一步&#xff0c;它帮助我们了解模型在解决特定问题上的表现如何&#xff0c;并且可以帮助我们选择最适合我们需求的算法。下面是分类与预测算法评价的一般介绍&#xff1a; 分类与预测问题 分类问题&#xff1a;是指将数据分为预…

大型组织企业 怎么实现便捷高效的跨地区文件交换?

大型组织企业&#xff0c;尤其是银行、邮政、大型集团、跨国企业等&#xff0c;都会存在多个分支机构&#xff0c;会面临跨地区文件交换的场景和需求。 跨地区文件交换可能会遇到以下问题&#xff1a; 1、网络带宽限制&#xff1a;跨国或跨大陆传输时&#xff0c;网络带宽可能…

全量知识系统 程序详细设计 库模式的存储库模型: “三生”(派生衍生自生) (QA百度文库)

Q1.请仔细说说 派生和衍生 各自的意思以及关系 派生和衍生都是常见的词汇&#xff0c;它们各自的意思如下&#xff1a; 派生&#xff1a;派生通常指的是从一个基本或原始的概念、理论、物质等中分化或发展出来的新的概念、理论、物质等。例如&#xff0c;在英语中&#xff0c…

Git - 在PyCharm/Idea中集成使用Git

文章目录 Git - 在PyCharm/Idea中集成使用Git1.新建GitHub仓库2.将仓库与项目绑定3.在PyCharm中使用Git4.新建Gitee仓库5.将仓库与项目绑定6.在IDEA中使用Git Git - 在PyCharm/Idea中集成使用Git 本文详细讲解了如何在 PyCharm 或 Idea 中配置 Gitee 或 GitHub 仓库&#xff0…

图像哈希:全局+局部提取特征

文章信息 作者&#xff1a;梁小平&#xff0c;唐振军期刊&#xff1a;ACM Trans. Multimedia Comput. Commun. Appl&#xff08;三区&#xff09;题目&#xff1a;Robust Hashing via Global and Local Invariant Features for Image Copy Detection 目的、实验步骤及结论 目…

Pytest精通指南(28)钩子函数-测试报告(pytest-html)

文章目录 前言应用场景插件安装参数分析使用方法拓展-定制化报告 前言 在软件开发过程中&#xff0c;测试是确保代码质量的关键环节。 而测试报告则是测试过程中不可或缺的输出物&#xff0c;它为我们提供了关于测试用例执行情况的详细信息&#xff0c;帮助我们快速定位和解决问…

20240417金融读报:金融支持制造通知外汇局修订资本项目指引碳足迹现状与痛点

1、《关于深化制造业金融服务 助力推进新型工业化的通知》强化制造业中长期贷款和信用贷款支持&#xff0c;重点服务基础/创新行业&#xff0c;支持设备以旧换新&#xff08;更绿色、更智能&#xff09; 2、国家外汇局修订资本项目外汇业务指引&#xff0c;2024版5月6日起执行&…