• 使用 Kubeadm 部署 Kubernetes(K8S) 安装


    1. 安装要求

    在开始之前,部署Kubernetes集群机器需要满足以下几个条件:

    • 一台或多台机器,操作系统 CentOS7.x-86_x64
    • 硬件配置:2GB或更多RAM,2个CPU或更多CPU,硬盘30GB或更多
    • 可以访问外网,需要拉取镜像,如果服务器不能上网,需要提前下载镜像并导入节点
    • 禁止swap分区

    2. 准备环境

    角色 IP HostName
    master 172.16.3.181 k8smaster
    node1 172.16.3.182 k8snode1
    node2 172.16.3.183 k8snode2

    2.1. 基础配置

    # 关闭防火墙
    [root@localhost ~]# firewall-cmd --state #查看防火墙状态
    [root@localhost ~]# systemctl stop firewalld     # 停止防火墙的服务
    [root@localhost ~]# systemctl disable firewalld    # 禁止开机启动
    
    # 关闭selinux
    [root@localhost ~]# setenforce 0  # 临时(当前不用重启)
    [root@localhost ~]# sed -i 's/enforcing/disabled/' /etc/selinux/config  # 永久(重启后生效)
    
    [root@localhost ~]# sestatus -v  # 查看状态(需要重启生效)
    
    # 关闭swap
    [root@localhost ~]# swapoff -a  # 临时
    [root@localhost ~]# sed -ri 's/.*swap.*/#&/' /etc/fstab    # 永久
    
    
    # 根据规划设置主机名
    [root@localhost ~]# hostnamectl set-hostname k8smaster  #其它的服务器为 k8snode1,k8snode2
    
    # 在master添加hosts
    [root@localhost ~]# cat >> /etc/hosts << EOF
    172.16.3.181 k8smaster
    172.16.3.182 k8snode1
    172.16.3.183 k8snode2
    EOF
    
    # 将桥接的IPv4流量传递到iptables的链(三台都执行)
    [root@localhost ~]# cat > /etc/sysctl.d/k8s.conf << EOF
    net.bridge.bridge-nf-call-ip6tables = 1
    net.bridge.bridge-nf-call-iptables = 1 
    net.ipv4.ip_forward=1
    net.ipv4.tcp_tw_recycle=0
    net.core.somaxconn=32768
    vm.swappiness=0  #禁止使用swap空间,只有当系统OOM时才允许使用它
    vm.overcommit_memory=1  #不检查物理内存是否够用
    vm.panic_on_oom=0  #开启OOM
    fs.inotify.max_user_instances=8192
    fs.inotify.max_user_watches=1048576
    fs.file-max=52706963
    fs.nr_open=52706963
    net.ipv6.conf.all.disable_ipv6=1
    net.netfilter.nf_conntrack_max=2310720
    EOF
    
    [root@localhost ~]# sysctl --system  # 生效--加载所有的配置文件
    [root@localhost ~]# sysctl -p /etc/sysctl.d/k8s.conf  # 单独指定配置文件加载
    
    # 时间同步
    [root@localhost ~]# yum install ntpdate -y
    [root@localhost ~]# ntpdate time.windows.com
    
    

    3. 所有节点安装Docker/kubeadm/kubelet

    Kubernetes默认CRI(容器运行时)为Docker,因此先安装Docker。

    3.1 安装Docker

    [root@localhost ~]# wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
    [root@localhost ~]# yum -y install docker-ce-19.03.11
    [root@localhost ~]# systemctl enable docker && systemctl start docker
    [root@localhost ~]# docker --version
    
    [root@localhost ~]# cat > /etc/docker/daemon.json << EOF
    {
      "registry-mirrors": ["https://b9pmyelo.mirror.aliyuncs.com"]
    }
    EOF 
    
    

    3.2 添加阿里云YUM软件源

    [root@localhost ~]# 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
    

    3.3 安装kubeadm,kubelet和kubectl

    由于版本更新频繁,这里指定版本号部署:建议安装新版,否则 kubesphere 低版本会有问题。
    image

    [root@localhost ~]# yum install -y kubelet-1.18.19 kubeadm-1.18.19 kubectl-1.18.19
    [root@localhost ~]# systemctl enable kubelet
    
    # kubelet-1.18.19  #部署在node节点最核心的组件  建议 v.20 + 版本
    # kubeadm-1.18.19  #安装k8s集群的工具  建议 v.20 + 版本
    # kubectl-1.18.19  #客户端工具  建议 v.20 + 版本
    

    4. 部署Kubernetes Master

    在172.16.3.181(Master)执行。

    [root@localhost ~]# kubeadm init \
      --apiserver-advertise-address=172.16.3.181 \
      --image-repository registry.aliyuncs.com/google_containers \
      --kubernetes-version v1.18.19 \
      --service-cidr=10.96.0.0/12 \
      --pod-network-cidr=10.244.0.0/16
    

    说明:
    --apiserver-advertise-address=172.16.3.181 #master的ip地址
    --image-repository registry.aliyuncs.com/google_containers #指定从什么位置拉取镜像
    --kubernetes-version=v1.18.19 #指定k8s版本,根据具体版本进行修改
    --service-cidr=10.96.0.0/16 #指定service网络的范围
    --pod-network-cidr=10.244.0.0/16 #指定pod网络的范围

    由于默认拉取镜像地址k8s.gcr.io国内无法访问,这里指定阿里云镜像仓库地址。

    image

    使用kubectl工具:

    [root@k8smaster ~]# mkdir -p $HOME/.kube
    [root@k8smaster ~]# sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
    [root@k8smaster ~]# sudo chown $(id -u):$(id -g) $HOME/.kube/config
    [root@k8smaster ~]# kubectl get nodes
    NAME        STATUS     ROLES    AGE     VERSION
    k8smaster   NotReady   master   5m40s   v1.18.19
    [root@k8smaster ~]# 
    

    5. 加入 K8S Node

    向集群添加新节点,执行在kubeadm init输出的kubeadm join命令:

    [root@k8snode2 ~]# kubeadm join 172.16.3.181:6443 --token jvv3up.7oy3647hgiozpoh7 \
        --discovery-token-ca-cert-hash sha256:962693618045022ac50317a00397e917dc5881ccb1152d53b586907ccc179724 
    

    默认token有效期为24小时,当过期之后,该token就不可用了。这时就需要重新创建token,操作如下:

    [root@k8snode2 ~]# kubeadm token create --print-join-command
    

    image
    再回到 Mater 上执行,会发现 node 已经加进来了
    image
    状态为 NotReady 需要安装 CNI 插件

    6. 部署CNI网络插件(在master节点执行)

    [root@k8smaster ~]# kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
    #查看 pods 情况
    [root@k8smaster ~]# kubectl get pods -n kube-system 
    #查看 nodes 情况
    [root@k8smaster ~]# kubectl get nodes
    

    如果 kubectl apply -f 后面的地址下不下来。可以单独下载下来。然后 apply 上去
    image

    7. 安装ingress-nginx组件(在master节点执行)

    详见:使用 Kubeadm 部署 Kubernetes(K8S) 安装 -- Ingress

    9. 测试kubernetes集群

    在Kubernetes集群中创建一个pod,验证是否正常运行:

    # 拉一个 Nginx 下来,便于测试用
    [root@k8smaster ~]# kubectl create deployment nginx --image=nginx
    # 查看状态
    [root@k8smaster ~]# kubectl get pod
    # 对外暴露 80 端口
    [root@k8smaster ~]# kubectl expose deployment nginx --port=80 --type=NodePort
    # 查看
    [root@k8smaster ~]# kubectl get pod,svc 
    NAME                            READY   STATUS    RESTARTS   AGE
    pod/javademo1-d7856c75c-czv2g   1/1     Running   0          152m
    pod/javademo1-d7856c75c-n28rs   1/1     Running   0          151m
    pod/javademo1-d7856c75c-xzqjc   1/1     Running   0          151m
    pod/nginx-f89759699-5hkdw       1/1     Running   0          26d
    
    NAME                 TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)          AGE
    service/javademo1    NodePort    10.106.43.46           8111:31452/TCP   20d
    service/kubernetes   ClusterIP   10.96.0.1              443/TCP          26d
    service/nginx        NodePort    10.103.87.81           80:30339/TCP     26d
    [root@k8smaster ~]# 
    
    

    访问地址:http://NodeIP:Port

    image

    image

    image

  • 相关阅读:
    vue 使用 driver.js 页面分步引导
    Aword无题
    Text2Cypher:大语言模型驱动的图查询生成
    18——Swing程序设计
    芯片手册自用
    滑动窗口 ( 单调队列 )
    动态照片怎么制作?教你如何制作gif动图
    [回归指标]R2、PCC(Pearson’s r )
    软件工程从理论到实践客观题汇总(头歌第九章至第十七章)
    Redis 在 vivo 推送平台的应用与优化实践
  • 原文地址:https://www.cnblogs.com/vipsoft/p/16787676.html