• 【云原生Kubernetes系列第二篇】kubeadm v1.20 部署K8S 集群架构【admin部署】


    一、环境配置

    swapoff -a #临时
    sed -ri 's/.*swap.*/#&/' /etc/fstab #永久
    free -g #验证,swap 必须为 0
    • 1
    • 2
    • 3

    在这里插入图片描述
    在这里插入图片描述

    vim /etc/hosts
    192.168.10.27 master
    192.168.10.28 node01
    192.168.10.29 node02
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    1.2 将桥接的 IPv4 流量传递到 iptables 的链

    cat > /etc/sysctl.d/k8s.conf << EOF
    net.bridge.bridge-nf-call-ip6tables = 1
    net.bridge.bridge-nf-call-iptables = 1
    EOF
    sysctl --system
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    1.3 docker安装

    安装依赖包
    yum install -y yum-utils device-mapper-persistent-data lvm2
    
    • 1
    • 2

    在这里插入图片描述
    在这里插入图片描述

    1.4 设置阿里云镜像源【三台都要配置】

    cd /etc/yum.repos.d/
    yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    
    • 1
    • 2

    在这里插入图片描述

    1.5 安装docker-ce 社区版

    yum install -y docker-ce
    在这里插入图片描述

    1.6 环境配置

    systemctl stop firewalld
    systemctl disable firewalld
    
    setenforce 0
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    vim /etc/selinux/config
    SELINUX=disabled
    
    • 1
    • 2

    在这里插入图片描述

    systemctl start docker
    systemctl enable docker
    
    • 1
    • 2

    在这里插入图片描述

    1.7 所有节点配置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
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    1.8 安装 kubelet、kubeadm、kubectl 组件

    yum list|grep kube
    yum install -y kubelet-1.21.3 kubeadm-1.21.3 kubectl-1.21.3
    systemctl enable kubelet
    systemctl start kubelet
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述
    在这里插入图片描述

    1.9 master节点制作

    kubeadm init \
    --apiserver-advertise-address=192.168.10.27 \ 
    --image-repository registry.cn-hangzhou.aliyuncs.com/google_containers \
    --kubernetes-version v1.21.3 \
    --service-cidr=10.125.0.0/16 \
    --pod-network-cidr=10.150.0.0/16
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    #如有问题:【用这个】

    kubeadm init --apiserver-advertise-address=192.168.10.27 --image-repository registry.cn-hangzhou.aliyuncs.com/google_containers --kubernetes-version v1.21.3 --service-cidr=10.125.0.0/16 --pod-network-cidr=10.150.0.0/16
    
    • 1

    在这里插入图片描述

    1.10 创建K8S组件的家目录 提权(必做)

    mkdir -p $HOME/.kube
      sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
      sudo chown $(id -u):$(id -g) $HOME/.kube/config
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    ##镜像批量导出,方便以后使用docker save docker images | grep -v TAG | awk '{print $1":"$2}' -o name.tar.gz

    1.11 复制、记录申请加入集群命令【在两个节点服务器上写】

    kubeadm join 192.168.10.27:6443 --token d5vdqp.v3061iapuu2qyw03 \
    	--discovery-token-ca-cert-hash sha256:a873822aa2acddfdb6d39f4983fff83e695f66f3e37cd5bc3cc09d21765f69ca 
    
    
    • 1
    • 2
    • 3

    在这里插入图片描述
    在这里插入图片描述

    1.12 重新生成token

    #若token 过期或丢失,需要先申请新的token 令牌【令牌过期时间是:24小时,等过了24小时之后,令牌失效,使用下面这个命令进行刷新重新生成令牌!】

    kubeadm token create

    #列出token
    kubeadm token list  | awk -F" " '{print $1}' |tail -n 1
    #然后获取CA公钥的的hash值
    openssl x509 -pubkey -in /etc/kubernetes/pki/ca.crt | openssl rsa -pubin -outform der 2>/dev/null | openssl dgst -sha256 -hex | sed  's/^ .* //'
    
    #替换join中token及sha256:
    kubeadm join 192.168.10.27:6443 --token zwl2z0.arz2wvtrk8yptkyz \
        --discovery-token-ca-cert-hash sha256:e211bc7af55310303fbc7126a1bc7289f16b046f8798008b68ee01051361cf02
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    1.13 或者使用镜像包导入的方式完成flannel的部署#【三台都要写】

    kubectl apply -f \
    https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
    
    • 1
    • 2

    在这里插入图片描述
    在这里插入图片描述

    1.14 给node节点打上“node”的标签

    [root@master ~]# kubectl label node node01 node-role.kubernetes.io/node=node
    node/node01 labeled
    
    [root@master ~]# kubectl label node node02 node-role.kubernetes.io/node=node
    node/node02 labeled
    [root@master ~]# kubectl get nodes
    NAME     STATUS   ROLES                  AGE     VERSION
    master   Ready    control-plane,master   7m11s   v1.21.3
    node01   Ready    node                   2m32s   v1.21.3
    node02   Ready    node                   2m32s   v1.21.3
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述
    在这里插入图片描述
    //如果 kubectl get cs 发现集群不健康,更改以下两个文件

    vim /etc/kubernetes/manifests/kube-scheduler.yaml 
    vim /etc/kubernetes/manifests/kube-controller-manager.yaml
     # 修改如下内容
    把--bind-address=127.0.0.1变成--bind-address=192.168.10.27  #修改成k8s的控制节点master01的ip
    把httpGet:字段下的hosts由127.0.0.1变成192.168.10.27(有两处)
    #- --port=0     # 搜索port=0,把这一行注释掉
    
    systemctl restart kubelet
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    1.15在三个服务器上面都要配置这个,把flannel配置文件拉进去,然后执行他!

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    Linux编译器-gcc的使用
    SCDM 实例教程:基本几何建模
    纯css+js自制下拉框
    行业案例 | 全面防护 赛宁助力能源工控安全建设
    Lua脚本
    MySQL之创建高性能的索引(十二)
    Java:为什么要更新Java应用程序?
    Swift之深入解析子数组提取的性能优化
    以MapBox为核心构建Vue地图组件库教程
    操作系统实验四 进程间通信
  • 原文地址:https://blog.csdn.net/weixin_59663288/article/details/125994307