首页 > 系统相关 >5.CentOS-7-Minimal 安装KubernetesV1.23.17&DockerV20.10.23

5.CentOS-7-Minimal 安装KubernetesV1.23.17&DockerV20.10.23

时间:2024-04-15 21:56:47浏览次数:36  
标签:CentOS 17 23 -- containerd etc registry io k8s

1.环境准备

主节点 IP:192.168.254.130
node1 IP:192.168.254.131
node2 IP:192.168.254.132
OS version: CentOS 7 mini
CPU Architecture: x86_64/amd64
K8s version: v1.23.17
Docker version: 20.10.23

2.安装前准备

# 安装依赖
yum install -y curl wget systemd bash-completion lrzsz

# 同步服务器时间
timedatectl set-timezone Asia/Shanghai && timedatectl set-local-rtc 0
systemctl restart rsyslog
systemctl restart crond

# 修改主机名
## 主节点
hostnamectl set-hostname k8s-master
## 从节点
hostnamectl set-hostname k8s-node1
hostnamectl set-hostname k8s-node2
## 修改hosts
cat >/etc/hosts <<EOF
192.168.254.130    k8s-master
192.168.254.131    k8s-node1
192.168.254.132    k8s-node2
EOF

# 开启必要的 端口
## 直接关闭防火墙
systemctl disable firewalld.service && systemctl stop firewalld.service

3.容器运行时

# 转发IPv4并让iptables看到桥接流量
cat >/etc/modules-load.d/k8s.conf <<EOF
overlay
br_netfilter
EOF
modprobe overlay
modprobe br_netfilter

cat >/etc/sysctl.d/k8s.conf <<EOF
net.bridge.bridge-nf-call-iptables=1
net.bridge.bridge-nf-call-ip6tables=1
net.ipv4.ip_forward=1
EOF
sysctl --system

# 通过运行以下指令确认 br_netfilter 和 overlay 模块被加载
lsmod | egrep 'overlay|br_netfilter'

# 通过运行以下指令确认 net.bridge.bridge-nf-call-iptables配置中被设置为 1
sysctl net.bridge.bridge-nf-call-iptables net.bridge.bridge-nf-call-ip6tables net.ipv4.ip_forward

3.1.安装容器运行时

# k8sv1.24及以后不在支持 Docker Engine,所以要手动安装

# 安装 Docker Engine
  yum install -y yum-utils

## 设置yum阿里云镜像
  yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  mkdir -p /etc/docker

## 设置阿里云镜像/日志/cgroup驱动
cat >/etc/docker/daemon.json <<EOF
{
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "100m"
},
"storage-driver": "overlay2",
"storage-opts": [
"overlay2.override_kernel_check=true"
],
"registry-mirrors":["https://hub-mirror.c.163.com","https://docker.mirrors.ustc.edu.cn","https://registry.docker-cn.com"]
}
EOF

  yum makecache fast
  yum install -y docker-ce-20.10.23 docker-ce-cli-20.10.23 containerd.io
  systemctl daemon-reload
  systemctl enable docker && systemctl restart docker

# 安装containerd / docker (二选一)
## container-runtimes
  yum install -y yum-utils
  yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  yum makecache fast
  yum install -y containerd.io
  mkdir -p /etc/containerd

## 生成默认文件
  containerd config default > /etc/containerd/config.toml

## 编辑配置文件 设置驱动方式为systemd 设置pause镜像 镜像仓库的加速器
  sed -i "s#SystemdCgroup = false#SystemdCgroup = true#g" /etc/containerd/config.toml
  sed -i "s#registry.k8s.io#registry.cn-hangzhou.aliyuncs.com/google_containers#g" /etc/containerd/config.toml
  sed -i "/\[plugins.\"io.containerd.grpc.v1.cri\".registry.mirrors\]/a\        [plugins.\"io.containerd.grpc.v1.cri\".registry.mirrors.\"docker.io\"]" /etc/containerd/config.toml
  sed -i "/\[plugins.\"io.containerd.grpc.v1.cri\".registry.mirrors.\"docker.io\"\]/a\          endpoint = [\"https://hub-mirror.c.163.com\",\"https://docker.mirrors.ustc.edu.cn\",\"https://registry.docker-cn.com\"]" /etc/containerd/config.toml
  sed -i "/endpoint = \[\"https:\/\/hub-mirror.c.163.com\",\"https:\/\/docker.mirrors.ustc.edu.cn\",\"https:\/\/registry.docker-cn.com\"]/a\        [plugins.\"io.containerd.grpc.v1.cri\".registry.mirrors.\"registry.k8s.io\"]" /etc/containerd/config.toml
  sed -i "/\[plugins.\"io.containerd.grpc.v1.cri\".registry.mirrors.\"registry.k8s.io\"\]/a\          endpoint = [\"registry.cn-hangzhou.aliyuncs.com/google_containers\"]" /etc/containerd/config.toml
  sed -i "/endpoint = \[\"registry.cn-hangzhou.aliyuncs.com\/google_containers\"]/a\        [plugins.\"io.containerd.grpc.v1.cri\".registry.mirrors.\"k8s.gcr.io\"]" /etc/containerd/config.toml
  sed -i "/\[plugins.\"io.containerd.grpc.v1.cri\".registry.mirrors.\"k8s.gcr.io\"\]/a\          endpoint = [\"registry.cn-hangzhou.aliyuncs.com/google_containers\"]" /etc/containerd/config.toml

  systemctl daemon-reload
  systemctl enable containerd && systemctl restart containerd

4.安装 k8s

# 安装 kubeadm  kubelet
# 关闭swap分区或者禁用swap文件
swapoff -a && sed -ri 's/.*swap.*/#&/' /etc/fstab

# 关闭selinux
setenforce 0 && sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config

## 使用阿里云k8s源
cat >/etc/yum.repos.d/kubernetes.repo <<EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF

## 安装工具kubelet、kubeadm、kubectl
    yum install -y kubelet-1.23.17 kubeadm-1.23.17 kubectl-1.23.17 --disableexcludes=kubernetes
## 设置驱动方式为systemd
cat >/etc/sysconfig/kubelet <<EOF
KUBELET_EXTRA_ARGS="--cgroup-driver=systemd"
EOF

## 设置容器运行时(仅容器运行时为containerd才需要进行以下设置,容器运行时为Docker则不需要,否则会报错)
crictl config runtime-endpoint unix:///var/run/containerd/containerd.sock
crictl config image-endpoint unix:///var/run/containerd/containerd.sock
sed -i '/KUBELET_KUBEADM_ARGS/s/"$/ --container-runtime=remote --container-runtime-endpoint=unix:\/\/\/run\/containerd\/containerd.sock"/' /var/lib/kubelet/kubeadm-flags.env

## kubelet开机自启
  systemctl enable --now kubelet
## 查看kubelet状态
  systemctl status kubelet
## 如果报错,查询错误信息
  journalctl -xe

5.运行k8s (从节点不需要运行)

mkdir -p /k8sdata/log/
kubeadm init \
--apiserver-advertise-address=192.168.254.130 \ 
--image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers \
--kubernetes-version=v1.23.17 \
--service-cidr=10.96.0.0/12 \
--pod-network-cidr=10.244.0.0/16 | tee /k8sdata/log/kubeadm-init.log
(带\会报错 unknown command " " for "kubeadm init" )

kubeadm init --apiserver-advertise-address=192.168.254.130 --image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers --kubernetes-version=v1.23.17 --service-cidr=10.96.0.0/12 --pod-network-cidr=10.244.0.0/16 | tee /k8sdata/log/kubeadm-init.log

mkdir -p "$HOME"/.kube
cp -i /etc/kubernetes/admin.conf "$HOME"/.kube/config
chown "$(id -u)":"$(id -g)" "$HOME"/.kube/config

## 注意:
1. --apiserver-advertise-address=192.168.254.130 \ 服务器地址
2. 如果是搭建的服务器是主节点,则服务器至少2核2G,如果没有达到该配置但是仍想安装,则可以在kubeadm init 命令行中使用–ignore-preflight-errors=CpuNum即可忽略报错。
3. 如果初始化失败,通过kubeadm reset进行重设

6.安装网络系统(二选一)

flannel
mkdir -p /k8sdata/network/
wget --no-check-certificate -O /k8sdata/network/flannelkube-flannel.yml https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
kubectl create -f /k8sdata/network/flannelkube-flannel.yml
或者
kubectl create -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

calico
mkdir -p /k8sdata/network/
wget --no-check-certificate -O /k8sdata/network/calico.yml https://docs.projectcalico.org/manifests/calico.yaml
kubectl create -f /k8sdata/network/calico.yml

7.k8s命令补全

! grep -q kubectl "$HOME/.bashrc" && echo "source /usr/share/bash-completion/bash_completion" >>"$HOME/.bashrc"
! grep -q kubectl "$HOME/.bashrc" && echo "source <(kubectl completion bash)" >>"$HOME/.bashrc"
! grep -q kubeadm "$HOME/.bashrc" && echo "source <(kubeadm completion bash)" >>"$HOME/.bashrc"
! grep -q crictl "$HOME/.bashrc" && echo "source <(crictl completion bash)" >>"$HOME/.bashrc"
source "$HOME/.bashrc"

8.k8s常用命令

# 获取节点
  kubectl get nodes -o wide
# 实时查询nodes状态
  watch kubectl get nodes -o wide
# 获取pod
  kubectl get pods --all-namespaces -o wide
# 查看镜像列表
  kubeadm config images list
# 节点加入集群
  kubeadm token create --print-join-command
  kubeadm join 192.168.254.130:6443 --token sgdjaz.1rzpwz4wdcox0l03 --discovery-token-ca-cert-hash sha256:1745a7ad9531b935f54d7b6187c1635ac950b6fbd3b0dfeda415b20914aaefe7
# 描述node
  kubectl describe node k8s-master
# 描述pod
  kubectl describe pod --namespace=kube-flannel

该笔记参考出处 https://jonssonyan.com/2022/1/

标签:CentOS,17,23,--,containerd,etc,registry,io,k8s
From: https://www.cnblogs.com/look06888/p/18136381

相关文章

  • m基于FPGA的217卷积编码维特比译码verilog实现,包含testbench不使用IP核
    1.算法仿真效果Vivado2019.2   编码部分:   译码部分输出:   RTL图:   2.算法涉及理论知识概要2.1卷积编码       卷积编码是一种前向纠错编码方式,特别适用于无线通信和其他信道条件恶劣的应用场景。它主要通过卷积算子将信息序列映射成......
  • 最新《2023中国企业敏捷实践白皮书》发布|4月18日
    2023年是社会各行各业预期迎来复苏与强劲反弹的阶段,却意外遭遇现实的巨大挑战。同时,人工智能技术的飞速发展,组织面临的复杂性和多变性不断加剧,这不仅推动了工作方式和业务模式的演变,也为敏捷实践的有效落地带来了新的挑战。逆境向左,敏捷向右。让我们通过一年一度的中国敏捷实......
  • 17、BGP按组打包
    BGP按组打包目前现网路由表的快速增长,以及网络拓扑的复杂性导致BGP需要支持更多的邻居。特别是一些邻居数目多且路由量大的场景下,针对路由器需要给大量的BGP邻居发送路由,且大部分邻居具有相同出口策略的特点,要求较高的打包发包性能。按组打包技术将所有拥有共同出口策略的BGP......
  • 1017 A除以B(高精除以低精)
    方法:逐位试商法。测试点2:被除数小于除数#include<bits/stdc++.h>usingnamespacestd;intmain(){ strings; intb; cin>>s>>b; inta[1010],c[1010];for(inti=0;i<s.size();i++){//数字 a[i]=s[i]-'0'; } intcarry=0; for(inti=......
  • Mysql安装和远程登录--Centos7
    在Centos7中使用的包管理工具是yum,当然使用包管理工具安装也是最方便的。本文操作内容需要在root用户下,否则有些步骤无法成功执行。系统环境信息展示安装MySQL提供的RPMwgethttps://dev.mysql.com/get/mysql80-community-release-el7-11.noarch.rpm检查是否下载成功......
  • 云原生周刊:CNCF 2023 年度调查报告 | 2024.4.15
    开源项目推荐highlight该项目是一个开源全栈监控平台。其功能包括错误监控、会话重放、日志记录、分布式跟踪等。HelmComposeHelmCompose是一个helm插件,用于在单个配置文件中管理一个或多个图表的多个版本。HAMi异构AI计算虚拟化中间件(HAMi),是一个“一站式”图表,旨在......
  • 新手大白话 FSCTF 2023刷题记录1
    [FSCTF2023]源码!启动!进入页面ctrl+u查看源码得到flagwebshell是啥捏进入页面,发现给出源码笨办法,一个一个找出表情代表啥,最后发现为命令执行函数passthru,而passthru出现在了漏洞点eval处,也就是RCE漏洞,而且进一步查看发现没有过滤,直接打它:细狗2.0进入页面随意输入试试,......
  • centos7安装golang最新版1.21.1
    #先卸载旧的golangyumremovegolang#然后找到最新版本https://golang.google.cn/dl/#下载安装cd/usr/local/src wgethttps://golang.google.cn/dl/go1.21.1.linux-amd64.tar.gztar-zxvfgo1.21.1.linux-amd64.tar.gz-C/usr/local/#增加配置文件vim/etc/profi......
  • centos7 安装supervisor教程以及常见问题
    目录简介Supervisor是一个进程控制系统。它是一个C/S系统(注意:其提供WEB接口给用户查询和控制)。它允许用户去监控和控制在类UNIX系统的进程。它的目标与launchd、daemontools和runit有些相似。但是与它们不一样的是、它不是作为init(进程号pid是1)运行。它是......
  • Centos7 中使用Supervisor守护进程
    配置supervisor实现进程守护1.安装supervisoryuminstallSupervisor 2.启动服务supervisord-c/etc/supervisord.conf 进入cd/etc目录找到supervisord.conf配置文件和supervisord.d文件夹,使用vim编辑supervisord.conf文件,拉到最底部我们可以看到 fil......