码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【云原生Kubernetes系列第二篇】kubeadm v1.20 部署K8S 集群架构【admin部署】


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

    • 一、环境配置
      • 1.2 将桥接的 IPv4 流量传递到 iptables 的链
      • 1.3 docker安装
      • 1.4 设置阿里云镜像源【三台都要配置】
      • 1.5 安装docker-ce 社区版
      • 1.6 环境配置
      • 1.7 所有节点配置K8S源
      • 1.8 安装 kubelet、kubeadm、kubectl 组件
      • 1.9 master节点制作
      • 1.10 创建K8S组件的家目录 提权(必做)
      • 1.11 复制、记录申请加入集群命令【在两个节点服务器上写】
      • 1.12 重新生成token
      • 1.13 或者使用镜像包导入的方式完成flannel的部署#【三台都要写】
      • 1.14 给node节点打上“node”的标签
      • 1.15在三个服务器上面都要配置这个,把flannel配置文件拉进去,然后执行他!

    一、环境配置

    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配置文件拉进去,然后执行他!

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

  • 相关阅读:
    最炫表白网站html5源码_七夕程序员的十款表白源码_html+css+js
    数学建模学习(82):模拟退火算法(SA,matlab版本)
    VMware Fusion 13+Ubuntu ARM Server 22.04.3在M2芯片的Mac上共享文件夹
    小程序 | 实现本地生活的首页基础布局
    前端研习录(16)——JavaScript引入、注释及输出方式讲解及示例说明
    【gazebo要素10】制作移动的机器人
    汉字风格迁移篇---个人手写体汉字字体的学习与生成*
    ROS系统02——matlab读取ros话题消息代码
    leetcode 729. My Calendar I(日程1)
    记参加Microsoft Ignite 大会和北京CSDN创作者之夜
  • 原文地址:https://blog.csdn.net/weixin_59663288/article/details/125994307
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号