• kubernetes 安装


    kubeadm创建集群

    请参照以前Docker安装。先提前为所有机器安装Docker

    安装kubeadm

    • 一台兼容的 Linux 主机。Kubernetes 项目为基于 Debian 和 Red Hat 的 Linux 发行版以及一些不提供包管理器的发行版提供通用的指令
    • 每台机器 2 GB 或更多的 RAM (如果少于这个数字将会影响你应用的运行内存)
    • 2 CPU 核或更多
    • 集群中的所有机器的网络彼此均能相互连接(公网和内网都可以)
      • 设置防火墙放行规则
    • 节点之中不可以有重复的主机名、MAC 地址或 product_uuid。请参见这里了解更多详细信息。
      • 设置不同hostname
    • 开启机器上的某些端口。请参见这里 了解更多详细信息。
      • 内网互信
    • 禁用交换分区。为了保证 kubelet 正常工作,你 必须 禁用交换分区。
      • 永久关闭
     
    1、基础环境

    所有机器执行以下操作

    #各个机器设置自己的域名, 方便识别不设置也可以, 注意: 集群中name必须唯一
    hostnamectl set-hostname xxxx
    
    
    # 将 SELinux 设置为 permissive 模式(相当于将其禁用)
    sudo setenforce 0
    sudo sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config
    
    #关闭swap
    swapoff -a  
    sed -ri 's/.*swap.*/#&/' /etc/fstab
    
    #允许 iptables 检查桥接流量
    cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf
    br_netfilter
    EOF
    
    cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf
    net.bridge.bridge-nf-call-ip6tables = 1
    net.bridge.bridge-nf-call-iptables = 1
    EOF
    sudo sysctl --system
    2、安装kubelet、kubeadm、kubectl
    cat <<EOF | sudo tee /etc/yum.repos.d/kubernetes.repo
    [kubernetes]
    name=Kubernetes
    baseurl=http://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
    enabled=1
    gpgcheck=0
    repo_gpgcheck=0
    gpgkey=http://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
       http://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
    exclude=kubelet kubeadm kubectl
    EOF
    
    
    sudo yum install -y kubelet-1.20.9 kubeadm-1.20.9 kubectl-1.20.9 --disableexcludes=kubernetes
    
    sudo systemctl enable --now kubelet

    kubelet 现在每隔几秒就会重启,因为它陷入了一个等待 kubeadm 指令的死循环

    3、使用kubeadm引导集群
    下载各个机器需要的镜像
    sudo tee ./images.sh <<-'EOF'
    #!/bin/bash
    images=(
    kube-apiserver:v1.20.9
    kube-proxy:v1.20.9
    kube-controller-manager:v1.20.9
    kube-scheduler:v1.20.9
    coredns:1.7.0
    etcd:3.4.13-0
    pause:3.2
    )
    for imageName in ${images[@]} ; do
    docker pull registry.cn-hangzhou.aliyuncs.com/lfy_k8s_images/$imageName
    done
    EOF
       
    chmod +x ./images.sh && ./images.sh

    注意:主节点全都需要; 从节点其实只需要 kube-proxy

    初始化主节点
    #所有机器添加master域名映射, 【172.31.0.4】为master节点私网IP,以下需要修改为自己的
    echo "172.31.0.4 cluster-endpoint" >> /etc/hosts

    
    #主节点初始化
    kubeadm init \
    --apiserver-advertise-address=172.31.0.4 \
    --control-plane-endpoint=cluster-endpoint \
    --image-repository registry.cn-hangzhou.aliyuncs.com/lfy_k8s_images \
    --kubernetes-version v1.20.9 \
    --service-cidr=10.96.0.0/16 \
    --pod-network-cidr=192.168.0.0/16
    
    注意: 1、所有网络范围不重叠
    2、
    172.31.0.4 是你的master IP
    3、cluster-endpoint 自定义的master IP 域名映射
    4、registry.cn-hangzhou.aliyuncs.com/lfy_k8s_images 镜像仓库
    5、
    10.96.0.0/16 K8S内部服务的IP分配范围
    6、
    192.168.0.0/16 pod网络IP分配范围

    完成后会看到一下信息:(建议保存)

    Your Kubernetes control-plane has initialized successfully!
    
    To start using your cluster, you need to run the following as a regular user:
    
      mkdir -p $HOME/.kube
      sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
      sudo chown $(id -u):$(id -g) $HOME/.kube/config
    
    Alternatively, if you are the root user, you can run:
    
      export KUBECONFIG=/etc/kubernetes/admin.conf
    
    You should now deploy a pod network to the cluster.
    Run "kubectl apply -f [podnetwork].yaml" with one of the options listed at:
      https://kubernetes.io/docs/concepts/cluster-administration/addons/
    
    You can now join any number of control-plane nodes by copying certificate authorities
    and service account keys on each node and then running the following as root:
    
      kubeadm join cluster-endpoint:6443 --token hums8f.vyx71prsg74ofce7 \
        --discovery-token-ca-cert-hash sha256:a394d059dd51d68bb007a532a037d0a477131480ae95f75840c461e85e2c6ae3 \
        --control-plane 
    
    Then you can join any number of worker nodes by running the following on each as root:
    
    kubeadm join cluster-endpoint:6443 --token hums8f.vyx71prsg74ofce7 \
        --discovery-token-ca-cert-hash sha256:a394d059dd51d68bb007a532a037d0a477131480ae95f75840c461e85e2c6ae3

    根据信息提示执行:

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

    安装网络组件:

    calico官网

    curl https://docs.projectcalico.org/archive/v3.20/manifests/calico.yaml -O
    
    kubectl apply -f calico.yaml

    # 注意:
    如果改了pod网络分配范围,需要进入calico.yaml 中修改

       1、打开192.168.0.0.0/16 注释, 换成你自己的

    添加主节点:(注意: 初始化的主节点不需要重复加入了)

      kubeadm join cluster-endpoint:6443 --token hums8f.vyx71prsg74ofce7 \
        --discovery-token-ca-cert-hash sha256:a394d059dd51d68bb007a532a037d0a477131480ae95f75840c461e85e2c6ae3 \
        --control-plane 

    添加从节点:

    # 这个命令24h有效
    kubeadm join cluster-endpoint:6443 --token x5g4uy.wpjjdbgra92s25pp \ --discovery-token-ca-cert-hash sha256:6255797916eaee52bf9dda9429db616fcd828436708345a308f4b917d3457a22

    # 新令牌获取
    kubeadm token create --print-join-command
    高可用部署方式,也是在这一步的时候,使用添加主节点的命令即可
  • 相关阅读:
    搜索引擎常用技巧
    WinRaR去广告弹窗
    逆向破解之160个CrackMe —— 003
    逆向破解之160个CrackMe —— 002
    逆向破解之160个CrackMe —— 001(下)
    逆向破解之160个CrackMe —— 001(中)
    逆向破解之160个CrackMe —— 001(上)
    VMWare虚拟机无法开启,显示模块“Disk”启动失败解决办法
    uefi+gpt重装系统提示需要安装到gpt分区盘解决办法
    neg与sbb指令的结合使用
  • 原文地址:https://www.cnblogs.com/TF511/p/16458433.html
Copyright © 2020-2023  润新知