K8S集群搭建

k8s 集群安装

      • 1、kubeadm
      • 2、前置要求
      • 3、部署步骤
        • 1、安装三台虚拟机(博主用的是vagrant 快速安装)
        • 2、所有节点安装 Docker、kubeadm、kubelet、kubectl
        • 3、部署 k8s-master(操作master虚拟机,不需要全部)
        • 4、安装 Pod 网络插件(flannel)
      • 4、入门操作kubernetes集群
        • 1、在主节点上部署一个tomcat
          • 容灾恢复
          • 暴露pod端口与虚拟机端口的映射
          • 动态扩容测试,多台节点部署同一个容器
          • 删除部署信息
      • 5、K8S 细节
        • K8S文档
        • yaml 语法
        • Ingress
      • 6、kubesphere安装
        • kubesphere文档地址
        • 安装helm
        • 安装Tilller(Master执行)
        • 安装 OpenEBS 创建 LocalPV 存储类型
        • 在 Kubernetes 安装 KubeSphere
        • 最小化安装时 redis-xxxxx-xxxx 一直pending状态,错误解决
        • 最小化安装时 ks-account Init:1/2 问题 helm 版本 2.16.3 k8s版本 1.17.3,错误解决
        • 安装后如何开启安装 DevOps 系统
        • 扩展pod错误日志检查
      • 7、kubesphere操作

1、kubeadm

  1. kubeadm 是官方社区推出的一个用于快速部署 kubernetes 集群的工具。
    这个工具能通过两条指令完成一个 kubernetes 集群的部署:
  2. 创建一个 Master 节点
    $ kubeadm init
    
  3. 将一个 Node 节点加入到当前集群中
    $ kubeadm join 
    

2、前置要求

  1. 一台或多台机器,操作系统 CentOS7(博主3台)
  2. windows安装,vagrant和VirtualBox(博主使用的是vagrant创建的虚拟机)
  3. 集群中所有机器之间网络互通
  4. 可以访问外网,需要拉取镜像
  5. 禁止 swap 分区

3、部署步骤

1、安装三台虚拟机(博主用的是vagrant 快速安装)

  1. 可以使用 vagrant 快速创建三个虚拟机。虚拟机启动前先设置 virtualbox 的主机网络。现全部统一为 192.168.56.1,以后所有虚拟机都是 56.x 的 ip 地址。
    K8S集群搭建_第1张图片
  2. 设置虚拟机存储目录,防止硬盘空间不足
    K8S集群搭建_第2张图片
  3. 安装启动三个虚拟机。使用我们提供的 vagrant 文件(内容如下,文件名必须为VagrantFile,无后缀名),复制到非中文无空格目录下,运行 vagrant up 启动三个虚拟机,会自动下载容器,前往VirtualBox管理界面即可看到。
    Vagrant.configure("2") do |config|
       (1..3).each do |i|
            config.vm.define "k8s-node#{i}" do |node|
                # 设置虚拟机的Box
                node.vm.box = "centos/7"
    
                # 设置虚拟机的主机名
                node.vm.hostname="k8s-node#{i}"
    
                # 设置虚拟机的IP
                node.vm.network "private_network", ip: "192.168.56.#{99+i}", netmask: "255.255.255.0"
    
                # 设置主机与虚拟机的共享目录
                # node.vm.synced_folder "~/Documents/vagrant/share", "/home/vagrant/share"
    
                # VirtaulBox相关配置
                node.vm.provider "virtualbox" do |v|
                    # 设置虚拟机的名称 可以自己设置
                    v.name = "k8s-node#{i}"
                    # 设置虚拟机的内存大小
                    v.memory = 4096
                    # 设置虚拟机的CPU个数
                    v.cpus = 4
                end
            end
       end
    end
    
    K8S集群搭建_第3张图片
  4. 进入三个虚拟机,开启 root 的密码访问权限。vagrant 创建的虚拟机无法通过远程服务外部访问,需要进行设置。
    #k8s-node1 需要根据自己创建的名称进入
    vagrant ssh k8s-node1
    su root 密码为 vagrant
    vi /etc/ssh/sshd_config
    #修改 
    PasswordAuthentication yes/no
    #重启服务 
    service sshd restart
    
  5. 设置好 NAT 网络。
    K8S集群搭建_第4张图片
    • 三台机器都需要设置成NAT,选择成我们新建的NatNetwork。
      K8S集群搭建_第5张图片
  6. 设置 linux 环境(三个台机器都需要执行)
    #关闭防火墙:
    systemctl stop firewalld
    systemctl disable firewalld
    #关闭 selinux:
    sed -i 's/enforcing/disabled/' /etc/selinux/config
    setenforce 0
    #临时关闭 swap
    swapoff -a 
    #永久关闭 swap
    sed -ri 's/.*swap.*/#&/' /etc/fstab 
    #添加主机名与 IP 对应关系 需要换成自己虚拟机IP
    vi /etc/hosts
    10.0.2.15 k8s-node1
    10.0.2.4 k8s-node2
    10.0.2.5 k8s-node3
    #将桥接的 IPv4 流量传递到 iptables 的链:
    cat > /etc/sysctl.d/k8s.conf <.bridge.bridge-nf-call-ip6tables = 1
    net.bridge.bridge-nf-call-iptables = 1
    EOF
    sysctl --system
    #设置完后,可以试着能不能通过域名 ping 通各个机器
    ping k8s-node2
    
    K8S集群搭建_第6张图片

2、所有节点安装 Docker、kubeadm、kubelet、kubectl

Kubernetes 默认 CRI(容器运行时)为 Docker,因此先安装 Docker。三台机器都需要安装。

  1. 安装docker
    • 卸载系统之前的 docker
      yum remove docker \
      			docker-client \
      			docker-client-latest \
      			docker-common \
      			docker-latest \
      			docker-latest-logrotate \
      			docker-logrotate \
      			docker-engine
      
    • 安装 Docker-CE
      #安装必须的依赖
      sudo yum install -y yum-utils \
      	device-mapper-persistent-data \
      	lvm2
      #设置 docker repo 的 yum 位置
      yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/c
      #安装 docker,以及 docker-cli
      yum install -y docker-ce docker-ce-cli containerd.io
      #配置 docker 加速 可用自己阿里云的镜像服务中的加速地址
      mkdir -p /etc/docker
      sudo tee /etc/docker/daemon.json <<-'EOF'
      		 {
      		   "registry-mirrors": ["https://f2j2uztg.mirror.aliyuncs.com"]
      		 }
      		 EOF
      		{
      		  "registry-mirrors": ["https://f2j2uztg.mirror.aliyuncs.com"]
      		}
      #启动 docker & 设置 docker 开机自启
       sudo systemctl daemon-reload
       sudo systemctl restart docker
       systemctl enable docker
       #添加阿里云 yum 源
       /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
      
      K8S集群搭建_第7张图片
    • 基础环境准备好后,可以给三个虚拟机备份一下,到时候后续失败后可回退(之后都可自己备份)。
      K8S集群搭建_第8张图片
  2. 安装 kubeadm,kubelet 和 kubectl
    #安装
    yum install -y kubelet-1.17.3 kubeadm-1.17.3 kubectl-1.17.3
    #设置自启动和启动服务
    systemctl enable kubelet
    systemctl start kubelet
    #查看kubelet的状态 此时状态还不是启动状态 还有东西未配置完成。
    systemctl status kubelet
    #查看kubelet版本
    kubelet --version
    

3、部署 k8s-master(操作master虚拟机,不需要全部)

  1. master节点初始化

    • 在Master节点上,创建并执行master_images.sh。需要提前执行master_images.sh 会更快,初始化命令需要下载很多镜像,这个.sh 会依次下载需要的镜像。
      	#创建目录(省略),创建 master_images.sh,内容如下:
      	vi master_images.sh
      	#!/bin/bash
      	images=(
      		kube-apiserver:v1.17.3
      	    kube-proxy:v1.17.3
      		kube-controller-manager:v1.17.3
      		kube-scheduler:v1.17.3
      		coredns:1.6.5
      		etcd:3.4.3-0
      	    pause:3.1
      	)
      	for imageName in ${images[@]} ; do
      	    docker pull registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName
      	# docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName  k8s.gcr.io/$imageName
      	done
      
      #修改为当前用户可执行权限
      chmod 700 master_images.sh
      #执行脚本
      ./master_images.sh
      #查看下载了的镜像
      docker images
      
    • 初始化kubeadm(注意:–apiserver-advertise-address=10.0.2.15 :这里的IP地址是master主机的地址,为上面的eth0网卡的地址;)
    	#执行完毕后,后提示需要的后续操作,不要清屏,用于后续 从节点 绑定到master上
    	$ kubeadm init \
    	--apiserver-advertise-address=10.0.2.15 \
    	--image-repository registry.cn-hangzhou.aliyuncs.com/google_containers \
    	--kubernetes-version   v1.17.3 \
    	--service-cidr=10.96.0.0/16  \
    	--pod-network-cidr=10.244.0.0/16
    

    K8S集群搭建_第9张图片

  2. 测试Kubectl(主节点执行,从节点无需执行)
    目前 master 状态为 notReady。等待网络加入完成即可。

    #获取所有节点
    kubectl get nodes
    #查看kubelet日志
    journalctl -u kubelet 
    
    • 运行上述初始化的提示信息。

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

    在这里插入图片描述

4、安装 Pod 网络插件(flannel)

  1. 在master节点上执行按照POD网络插件

    #获取网络资源下载 flannel 不推荐
    kubectl apply -f \
    https://raw.githubusercontent.com/coreos/flanne/master/Documentation/kube-flannel.yml
    #以上地址可能被墙,可以直接获取本地已经下载的kube-flannel.yml运行即可,如:
    kubectl apply -f  kube-flannel.yml
    
  2. kube-flannel.yml内容如下,上传至master虚拟机

    ---
    kind: Namespace
    apiVersion: v1
    metadata:
      name: kube-flannel
      labels:
        pod-security.kubernetes.io/enforce: privileged
    ---
    kind: ClusterRole
    apiVersion: rbac.authorization.k8s.io/v1
    metadata:
      name: flannel
    rules:
    - apiGroups:
      - ""
      resources:
      - pods
      verbs:
      - get
    - apiGroups:
      - ""
      resources:
      - nodes
      verbs:
      - get
      - list
      - watch
    - apiGroups:
      - ""
      resources:
      - nodes/status
      verbs:
      - patch
    ---
    kind: ClusterRoleBinding
    apiVersion: rbac.authorization.k8s.io/v1
    metadata:
      name: flannel
    roleRef:
      apiGroup: rbac.authorization.k8s.io
      kind: ClusterRole
      name: flannel
    subjects:
    - kind: ServiceAccount
      name: flannel
      namespace: kube-flannel
    ---
    apiVersion: v1
    kind: ServiceAccount
    metadata:
      name: flannel
      namespace: kube-flannel
    ---
    kind: ConfigMap
    apiVersion: v1
    metadata:
      name: kube-flannel-cfg
      namespace: kube-flannel
      labels:
        tier: node
        app: flannel
    data:
      cni-conf.json: |
        {
          "name": "cbr0",
          "cniVersion": "0.3.1",
          "plugins": [
            {
              "type": "flannel",
              "delegate": {
                "hairpinMode": true,
                "isDefaultGateway": true
              }
            },
            {
              "type": "portmap",
              "capabilities": {
                "portMappings": true
              }
            }
          ]
        }
      net-conf.json: |
        {
          "Network": "10.244.0.0/16",
          "Backend": {
            "Type": "vxlan"
          }
        }
    ---
    apiVersion: apps/v1
    kind: DaemonSet
    metadata:
      name: kube-flannel-ds
      namespace: kube-flannel
      labels:
        tier: node
        app: flannel
    spec:
      selector:
        matchLabels:
          app: flannel
      template:
        metadata:
          labels:
            tier: node
            app: flannel
        spec:
          affinity:
            nodeAffinity:
              requiredDuringSchedulingIgnoredDuringExecution:
                nodeSelectorTerms:
                - matchExpressions:
                  - key: kubernetes.io/os
                    operator: In
                    values:
                    - linux
          hostNetwork: true
          priorityClassName: system-node-critical
          tolerations:
          - operator: Exists
            effect: NoSchedule
          serviceAccountName: flannel
          initContainers:
          - name: install-cni-plugin
           #image: flannelcni/flannel-cni-plugin:v1.1.0 for ppc64le and mips64le (dockerhub limitations may apply)
            image: docker.io/rancher/mirrored-flannelcni-flannel-cni-plugin:v1.1.0
            command:
            - cp
            args:
            - -f
            - /flannel
            - /opt/cni/bin/flannel
            volumeMounts:
            - name: cni-plugin
              mountPath: /opt/cni/bin
          - name: install-cni
           #image: flannelcni/flannel:v0.20.2 for ppc64le and mips64le (dockerhub limitations may apply)
            image: docker.io/rancher/mirrored-flannelcni-flannel:v0.20.2
            command:
            - cp
            args:
            - -f
            - /etc/kube-flannel/cni-conf.json
            - /etc/cni/net.d/10-flannel.conflist
            volumeMounts:
            - name: cni
              mountPath: /etc/cni/net.d
            - name: flannel-cfg
              mountPath: /etc/kube-flannel/
          containers:
          - name: kube-flannel
           #image: flannelcni/flannel:v0.20.2 for ppc64le and mips64le (dockerhub limitations may apply)
            image: docker.io/rancher/mirrored-flannelcni-flannel:v0.20.2
            command:
            - /opt/bin/flanneld
            args:
            - --ip-masq
            - --kube-subnet-mgr
            resources:
              requests:
                cpu: "100m"
                memory: "50Mi"
              limits:
                cpu: "100m"
                memory: "50Mi"
            securityContext:
              privileged: false
              capabilities:
                add: ["NET_ADMIN", "NET_RAW"]
            env:
            - name: POD_NAME
              valueFrom:
                fieldRef:
                  fieldPath: metadata.name
            - name: POD_NAMESPACE
              valueFrom:
                fieldRef:
                  fieldPath: metadata.namespace
            - name: EVENT_QUEUE_DEPTH
              value: "5000"
            volumeMounts:
            - name: run
              mountPath: /run/flannel
            - name: flannel-cfg
              mountPath: /etc/kube-flannel/
            - name: xtables-lock
              mountPath: /run/xtables.lock
          volumes:
          - name: run
            hostPath:
              path: /run/flannel
          - name: cni-plugin
            hostPath:
              path: /opt/cni/bin
          - name: cni
            hostPath:
              path: /etc/cni/net.d
          - name: flannel-cfg
            configMap:
              name: kube-flannel-cfg
          - name: xtables-lock
            hostPath:
              path: /run/xtables.lock
              type: FileOrCreate
    

    K8S集群搭建_第10张图片

  3. 如果改网络插件安装失败,没有下面的效果,可以使用命令删除当前的网络插件。或者查看日志,报错信息就行排错。(博主:master节点的状态一直为NotReady,后使用 查看日志的方式进行排错,是kube-flannel的配置安装不成功,后来删除网络插件,换成上述版本的kube-flannel.yml解决)

    #删除网络插件
    kubectl deleted -f  kube-flannel.yml
    #查看日志,进行排错
    journalctl -u kubelet -f
    

    K8S集群搭建_第11张图片

  4. 等待大约3分钟。才可启动安装成功

    #查看命名空间
    kubectl get ns
    NAME              STATUS   AGE
    default           Active   30m
    kube-node-lease   Active   30m
    kube-public       Active   30m
    kube-system       Active   30m
    #查看指定名称空间的pods
    kubectl get pods -n kube-system 
    #查看所有名称空间的pods
    kubectl get pods --all-namespaces
    
  5. 查看master上的节点信息

    kubectl get nodes
    NAME        STATUS   ROLES    AGE   VERSION
    k8s-node1   Ready    master   34m   v1.17.3   #status为ready才能够执行下面的命令
    

    K8S集群搭建_第12张图片

  6. 最后另外两台虚拟上,“k8s-node2”和“k8s-node3”上也执行初始化kubeadm后提示的命令:

    kubeadm join 10.0.2.15:6443 --token c2wwkc.y0igkd4d406m0dpo \
        --discovery-token-ca-cert-hash sha256:355cdbc0daa969295e7de43c20f623818f61367530b0ee632b26d85dfd7d182b
    
  7. 如果上述token使用时间过期,需要在master上重新生成一个,在把discovery-token-ca-cert-hash sha256指定的值替换即可。

    kubeadm token create --print-join-command
    #设置token 永不过期
    kubeadm token create --ttl 0 --print-join-command
    
  8. 在master上查看所有节点状态。如果全部节点为ready,集群搭建成功。

    #执行监控 pod 进度
    watch kubectl get pod -n kube-system -o wide 
    #等 3-10 分钟,完全都是 running 以后使用 kubectl get nodes 检查状态
    kubectl get nodes
    

    K8S集群搭建_第13张图片

4、入门操作kubernetes集群

1、在主节点上部署一个tomcat

容灾恢复
  1. 主节点部署tomcat,查看所有资源,获取所有资源部署详细信息
    #在主节点上部署一个tomcat
    kubectl create deployment tomcat6 --image=tomcat:6.0.53-jre8
    #获取所有的资源
    kubectl get all
    #kubectl get pods -o wide 可以获取到tomcat部署信息,能够看到它被部署到了k8s-node3上了
    kubectl get pods -o wide
    
    K8S集群搭建_第14张图片
  2. 查看node3节点上,下载了哪些镜像和运行了那些容器。
    K8S集群搭建_第15张图片
  3. 停止node3的容器,k8s会自动重新启动一个容器,保证该容器一定有一个在运行。
    K8S集群搭建_第16张图片
  4. 模拟机器宕机,关闭node3虚拟机,查看在master上查看每个node状态,以及Tomact容器状态(需要过几分钟后)。k8s会容灾恢复,保证有一个可运行的容器。
    K8S集群搭建_第17张图片K8S集群搭建_第18张图片
  5. 再起启动node3节点,master查看节点状态恢复,tomcat容器中断命令也会发出。
    K8S集群搭建_第19张图片
暴露pod端口与虚拟机端口的映射
  1. 在master上执行
    #暴露pod内容器端口和 pod端口直接的映射 port指定pod端口 target-port 指定在pod中运行的容器端口
    kubectl expose deployment tomcat6 --port=80 --target-port=8080 --type=NodePort 
    
  2. 查看所有服务和详细信息,虚拟端口映射的pod端口,通过虚拟IP:端口进行访问。
    #查看服务
    kubectl get svc
    #查看服务详细信息 即可查看到虚拟机ip映射到pod的端口
    kubectl get svc -o wide
    
    K8S集群搭建_第20张图片
动态扩容测试,多台节点部署同一个容器
#查看部署信息
kubectl get deployment
#动态扩容部署信息 扩充pod的运行数量
kubectl scale --replicas=3 deployment tomcat6
#扩容后查看pod的信息
kubectl get pods -o wide
#查看服务信息  服务信息只会有一个 pod有多个
kubectl get svc -o wide    

K8S集群搭建_第21张图片

删除部署信息
#查看所有资源
kubectl get all
#删除deployment.apps/tomcat6 
kubectl delete  deployment.apps/tomcat6 
#查看剩余的资源
kubectl get all   
#删除service/tomcat6 
kubectl delete service/tomcat6  
#查看剩余的资源
kubectl get all

K8S集群搭建_第22张图片

5、K8S 细节

K8S文档

  1. kubectl 文档
  2. 命令参考

yaml 语法

  1. 部署一个 tomcat 输出yaml
    #查看帮助命令
    kubectl create deployment tomcat6 --image=tomcat:6.0.53-jre8 --help
    #测试生成yaml 不会创建运行部署容器
    kubectl create deployment tomcat6 --image=tomcat:6.0.53-jre8 --dry-run -o yaml
    #生成的yaml写入文件
    kubectl create deployment tomcat6 --image=tomcat:6.0.53-jre8 --dry-run -o yaml > tomcat6.yaml
    #编辑yaml 文件内容如下图 然后指定文件应用或更新创建运行唤醒
    kubectl apply -f tomcat6.yaml
    #再次查看pod详细信息
    kubectl get pods -o wide
    
    K8S集群搭建_第23张图片K8S集群搭建_第24张图片
  2. 部署一个服务service,命令行方式转成yaml
    #将服务命令转成yaml文件存储
    kubectl expose deployment tomcat6 --port=80 --target-port=8080 --type=NodePort --dry-run -o yaml > tomcat6-service.yaml
    #具体内容请看图片 然后运行执行yaml文件创建服务
    kubectl apply -f tomcat6-service.yaml
    #插看所有信息
    kubectl get all
    
    K8S集群搭建_第25张图片
  3. 部署pod,命令行方式转成yaml。
    #将其中的某个pod装成yaml存储 tomcat6-5f7ccf4cb9-fpf6h是pod的唯一标识
    kubectl get pod tomcat6-5f7ccf4cb9-fpf6h -o yaml
    #修改pod.yaml内容如下图 然后运行 查看结果
    kubectl apply -f tomcat-pod.yaml
    
    K8S集群搭建_第26张图片
  4. 将上述所有的yaml合并到一个文件中,每个片段之间用 — 分割,即可实现一次性部署和暴露和创建pod。
    K8S集群搭建_第27张图片

Ingress

  1. 通过 Service 发现 Pod 进行关联。基于域名访问。通过 Ingress Controller 实现 Pod 负载均衡。实现通过域名访问service,在由service负载均衡转发到pod。
    K8S集群搭建_第28张图片
  2. 部署Ingress controller,执行“k8s/ingress-controller.yaml”
    apiVersion: v1
    kind: Namespace
    metadata:
      name: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    
    ---
    
    kind: ConfigMap
    apiVersion: v1
    metadata:
      name: nginx-configuration
      namespace: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    
    ---
    kind: ConfigMap
    apiVersion: v1
    metadata:
      name: tcp-services
      namespace: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    
    ---
    kind: ConfigMap
    apiVersion: v1
    metadata:
      name: udp-services
      namespace: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    
    ---
    apiVersion: v1
    kind: ServiceAccount
    metadata:
      name: nginx-ingress-serviceaccount
      namespace: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    
    ---
    apiVersion: rbac.authorization.k8s.io/v1beta1
    kind: ClusterRole
    metadata:
      name: nginx-ingress-clusterrole
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    rules:
      - apiGroups:
          - ""
        resources:
          - configmaps
          - endpoints
          - nodes
          - pods
          - secrets
        verbs:
          - list
          - watch
      - apiGroups:
          - ""
        resources:
          - nodes
        verbs:
          - get
      - apiGroups:
          - ""
        resources:
          - services
        verbs:
          - get
          - list
          - watch
      - apiGroups:
          - "extensions"
        resources:
          - ingresses
        verbs:
          - get
          - list
          - watch
      - apiGroups:
          - ""
        resources:
          - events
        verbs:
          - create
          - patch
      - apiGroups:
          - "extensions"
        resources:
          - ingresses/status
        verbs:
          - update
    
    ---
    apiVersion: rbac.authorization.k8s.io/v1beta1
    kind: Role
    metadata:
      name: nginx-ingress-role
      namespace: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    rules:
      - apiGroups:
          - ""
        resources:
          - configmaps
          - pods
          - secrets
          - namespaces
        verbs:
          - get
      - apiGroups:
          - ""
        resources:
          - configmaps
        resourceNames:
          # Defaults to "-"
          # Here: "-"
          # This has to be adapted if you change either parameter
          # when launching the nginx-ingress-controller.
          - "ingress-controller-leader-nginx"
        verbs:
          - get
          - update
      - apiGroups:
          - ""
        resources:
          - configmaps
        verbs:
          - create
      - apiGroups:
          - ""
        resources:
          - endpoints
        verbs:
          - get
    
    ---
    apiVersion: rbac.authorization.k8s.io/v1beta1
    kind: RoleBinding
    metadata:
      name: nginx-ingress-role-nisa-binding
      namespace: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    roleRef:
      apiGroup: rbac.authorization.k8s.io
      kind: Role
      name: nginx-ingress-role
    subjects:
      - kind: ServiceAccount
        name: nginx-ingress-serviceaccount
        namespace: ingress-nginx
    
    ---
    apiVersion: rbac.authorization.k8s.io/v1beta1
    kind: ClusterRoleBinding
    metadata:
      name: nginx-ingress-clusterrole-nisa-binding
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    roleRef:
      apiGroup: rbac.authorization.k8s.io
      kind: ClusterRole
      name: nginx-ingress-clusterrole
    subjects:
      - kind: ServiceAccount
        name: nginx-ingress-serviceaccount
        namespace: ingress-nginx
    
    ---
    
    apiVersion: apps/v1
    kind: DaemonSet 
    metadata:
      name: nginx-ingress-controller
      namespace: ingress-nginx
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    spec:
      selector:
        matchLabels:
          app.kubernetes.io/name: ingress-nginx
          app.kubernetes.io/part-of: ingress-nginx
      template:
        metadata:
          labels:
            app.kubernetes.io/name: ingress-nginx
            app.kubernetes.io/part-of: ingress-nginx
          annotations:
            prometheus.io/port: "10254"
            prometheus.io/scrape: "true"
        spec:
          hostNetwork: true
          serviceAccountName: nginx-ingress-serviceaccount
          containers:
            - name: nginx-ingress-controller
              image: siriuszg/nginx-ingress-controller:0.20.0
              args:
                - /nginx-ingress-controller
                - --configmap=$(POD_NAMESPACE)/nginx-configuration
                - --tcp-services-configmap=$(POD_NAMESPACE)/tcp-services
                - --udp-services-configmap=$(POD_NAMESPACE)/udp-services
                - --publish-service=$(POD_NAMESPACE)/ingress-nginx
                - --annotations-prefix=nginx.ingress.kubernetes.io
              securityContext:
                allowPrivilegeEscalation: true
                capabilities:
                  drop:
                    - ALL
                  add:
                    - NET_BIND_SERVICE
                # www-data -> 33
                runAsUser: 33
              env:
                - name: POD_NAME
                  valueFrom:
                    fieldRef:
                      fieldPath: metadata.name
                - name: POD_NAMESPACE
                  valueFrom:
                    fieldRef:
                      fieldPath: metadata.namespace
              ports:
                - name: http
                  containerPort: 80
                - name: https
                  containerPort: 443
              livenessProbe:
                failureThreshold: 3
                httpGet:
                  path: /healthz
                  port: 10254
                  scheme: HTTP
                initialDelaySeconds: 10
                periodSeconds: 10
                successThreshold: 1
                timeoutSeconds: 10
              readinessProbe:
                failureThreshold: 3
                httpGet:
                  path: /healthz
                  port: 10254
                  scheme: HTTP
                periodSeconds: 10
                successThreshold: 1
                timeoutSeconds: 10
    
    ---
    apiVersion: v1
    kind: Service
    metadata:
      name: ingress-nginx
      namespace: ingress-nginx
    spec:
      #type: NodePort
      ports:
      - name: http
        port: 80
        targetPort: 80
        protocol: TCP
      - name: https
        port: 443
        targetPort: 443
        protocol: TCP
      selector:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
    
    #创建 ingress.yaml文件
    vi ingress-controller.yaml
    #执行
    kubectl apply -f ingress-controller.yaml
    
    K8S集群搭建_第29张图片
  3. windows配置访问域名,通过域名访问,部署信息。
    K8S集群搭建_第30张图片

6、kubesphere安装

  • 默认的dashboard没啥用,我们用kubesphere可以打通全部的devops链路,kubesphere集成了很多套件,集群要求比较高。
  • kuboard也很不错,集群要求不高, 官方地址

kubesphere文档地址

  • 官方文档
  • 安装前置环境准备
  • Kubernetes 安装 KubeSphere

安装helm

  1. 要根据对应的 Kubernetes的版本安装对应的helm版本。helm2.16.2下载地址,可下载后直接上传至虚拟机。
    K8S集群搭建_第31张图片
    K8S集群搭建_第32张图片

    #命令下载 会比较慢
    wget https://get.helm.sh/helm-v2.16.2-linux-amd64.tar.gz
    
  2. 解压压缩包和移动解压文件。

    #解压文件到指定目录
    tar -zxvf helm-v2.16.2-linux-amd64.tar.gz -C /mydata/helm
    #进入解压目录
    cd /mydata/helm
    #移动文件至bin目录
    sudo mv linux-amd64/helm /usr/local/bin/helm
    #查看helm是否安装 能打印出信息即安装成功
    helm
    
  3. 创建权限(master执行)

    #创建yaml文件 内容在下面
    vi helm-rbac.yaml
    
    apiVersion: v1
    kind: ServiceAccount
    metadata:
      name: tiller
      namespace: kube-system
    ---
    apiVersion: rbac.authorization.k8s.io/v1
    kind: ClusterRoleBinding
    metadata:
      name: tiller
    roleRef:
      apiGroup: rbac.authorization.k8s.io
      kind: ClusterRole
      name: cluster-admin
    subjects: 
      - kind: ServiceAccount
        name: tiller
        namespace: kube-system
    
    #执行
    [root@k8s-node1 k8s]#  kubectl apply -f helm-rbac.yaml
    serviceaccount/tiller created
    clusterrolebinding.rbac.authorization.k8s.io/tiller created
    

安装Tilller(Master执行)

  1. 修改镜像,不修改可能无法。
    helm repo list
    helm repo add stable https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts
    
  2. 执行初始化Tilller
    #需要等待一段时间后才可初始化完成 --tiller-image 指定镜像,否则会被墙,等待节点上部署的tiller完成即可。
    helm init --service-account=tiller --tiller-image=registry.cn-hangzhou.aliyuncs.com/google_containers/tiller:v2.16.3   --history-max 300
    #检查版本
    helm version
    
    K8S集群搭建_第33张图片

安装 OpenEBS 创建 LocalPV 存储类型

  1. 前提条件(同样也参考文档,一步一步来) 安装步骤官方文档

    • 已有 Kubernetes 集群,并安装了 kubectl 或 Helm
    • Pod 可以被调度到集群的 master 节点(可临时取消 master 节点的 Taint)
  2. 查看节点,确认 master 节点是否有 Taint,去掉 master 节点的 Taint。

    #查看节点
    kubectl get node -o wide
    #确认 master 节点是否有 Taint
    kubectl describe node master | grep Taint
    #去掉 master 节点的 Taint。 之后在安装KubeSphere之前不要打开了
    kubectl taint nodes master node-role.kubernetes.io/master:NoSchedule-
    

    在这里插入图片描述

  3. 安装 OpenEBS

    #创建命名空间
    kubectl create ns openebs
    #换镜像
    helm repo add stable http://mirror.azure.cn/kubernetes/charts
    #安装
    helm install --namespace openebs --name openebs stable/openebs --version 1.5.0
    #查看所有命名空间
    kubectl get ns
    #如果安装失败了可以删除helm中的应用 查看所有应用
    helm ls --all
    #删除helm中的应用 xxx 应用名称
    helm del --purge xxx
    

K8S集群搭建_第34张图片
4. 查看创建的 StorageClass,设置为 默认的 StorageClass

#安装 OpenEBS 后将自动创建 4 个 StorageClass,查看创建的 StorageClass:
kubectl get sc
#将 openebs-hostpath设置为 默认的 StorageClass
kubectl patch storageclass openebs-hostpath -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"true"}}}'

K8S集群搭建_第35张图片
5. master 节点 Taint 加上,避免业务相关的工作负载调度到 master 节点抢占 master 资源

kubectl taint nodes master node-role.kubernetes.io/master=:NoSchedule

在 Kubernetes 安装 KubeSphere

  • 安装步骤官方文档
  1. 最小化安装 KubeSphere,不用官网的安装方式,连接已经失效了。

    #linux中新建 文件 内容如下
    vim kubesphere-minimal.yaml
    
    ---
    apiVersion: v1
    kind: Namespace
    metadata:
      name: kubesphere-system
    
    ---
    apiVersion: v1
    data:
      ks-config.yaml: |
        ---
    
        persistence:
          storageClass: ""
    
        etcd:
          #是否开启etcd 想开启可以设置为True
          monitoring: False
          endpointIps: 192.168.0.7,192.168.0.8,192.168.0.9
          port: 2379
          tlsEnable: True
    
        common:
          mysqlVolumeSize: 20Gi
          minioVolumeSize: 20Gi
          etcdVolumeSize: 20Gi
          openldapVolumeSize: 2Gi
          redisVolumSize: 2Gi
    
        metrics_server:
          enabled: False
    
        console:
          enableMultiLogin: False  # enable/disable multi login
          port: 30880
    
        monitoring:
          prometheusReplicas: 1
          prometheusMemoryRequest: 400Mi
          prometheusVolumeSize: 20Gi
          grafana:
            enabled: False
    
        logging:
         	#是否开启日志功能 想开启可以设置为True
          enabled: False
          elasticsearchMasterReplicas: 1
          elasticsearchDataReplicas: 1
          logsidecarReplicas: 2
          elasticsearchMasterVolumeSize: 4Gi
          elasticsearchDataVolumeSize: 20Gi
          logMaxAge: 7
          elkPrefix: logstash
          containersLogMountedPath: ""
          kibana:
            enabled: False
    
        openpitrix:
          enabled: False
    
        devops:
          #是否开启devops功能 之后会设置成true
          enabled: False
          jenkinsMemoryLim: 2Gi
          jenkinsMemoryReq: 1500Mi
          jenkinsVolumeSize: 8Gi
          jenkinsJavaOpts_Xms: 512m
          jenkinsJavaOpts_Xmx: 512m
          jenkinsJavaOpts_MaxRAM: 2g
          sonarqube:
            enabled: False
            postgresqlVolumeSize: 8Gi
    
        servicemesh:
          enabled: False
    
        notification:
          enabled: False
    
        alerting:
          enabled: False
    
    kind: ConfigMap
    metadata:
      name: ks-installer
      namespace: kubesphere-system
    
    ---
    apiVersion: v1
    kind: ServiceAccount
    metadata:
      name: ks-installer
      namespace: kubesphere-system
    
    ---
    apiVersion: rbac.authorization.k8s.io/v1
    kind: ClusterRole
    metadata:
      creationTimestamp: null
      name: ks-installer
    rules:
    - apiGroups:
      - ""
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - apps
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - extensions
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - batch
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - rbac.authorization.k8s.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - apiregistration.k8s.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - apiextensions.k8s.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - tenant.kubesphere.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - certificates.k8s.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - devops.kubesphere.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - monitoring.coreos.com
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - logging.kubesphere.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - jaegertracing.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - storage.k8s.io
      resources:
      - '*'
      verbs:
      - '*'
    - apiGroups:
      - admissionregistration.k8s.io
      resources:
      - '*'
      verbs:
      - '*'
    
    ---
    kind: ClusterRoleBinding
    apiVersion: rbac.authorization.k8s.io/v1
    metadata:
      name: ks-installer
    subjects:
    - kind: ServiceAccount
      name: ks-installer
      namespace: kubesphere-system
    roleRef:
      kind: ClusterRole
      name: ks-installer
      apiGroup: rbac.authorization.k8s.io
    
    ---
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: ks-installer
      namespace: kubesphere-system
      labels:
        app: ks-install
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: ks-install
      template:
        metadata:
          labels:
            app: ks-install
        spec:
          serviceAccountName: ks-installer
          containers:
          - name: installer
            image: kubesphere/ks-installer:v2.1.1
            imagePullPolicy: "Always"
    
  2. 执行

    kubectl apply -f kubesphere-minimal.yaml
    
  3. 验证与访问,查看滚动刷新的安装日志,请耐心等待(需要一定时间)安装成功。

    kubectl logs -n kubesphere-system $(kubectl get pod -n kubesphere-system -l app=ks-install -o jsonpath='{.items[0].metadata.name}') -f
    
  4. 如果日志中报错,可自行搜索错误信息进行解决。

  5. 如何重启安装。若安装过程中遇到问题,当您解决问题后,可以通过重启 ks-installer 的 Pod 来重启安装任务,将 ks-installer 的 Pod 删除即可让其自动重启:

    #删除后会自动重新 ks-installer-xxxxxx-xxxxx 是pod的name
    kubectl delete pod ks-installer-xxxxxx-xxxxx -n kubesphere-system
    
  6. 通过 kubectl get pod --all-namespaces查看 KubeSphere 相关 namespace 下所有 Pod 状态是否为 Running.确认 Pod 都正常运行后,可使用 IP:30880访问 KubeSphere UI 界面,默认的集群管理员账号为 admin/P@88w0rd。
    K8S集群搭建_第36张图片
    K8S集群搭建_第37张图片
    K8S集群搭建_第38张图片

最小化安装时 redis-xxxxx-xxxx 一直pending状态,错误解决

  1. 关掉污点,删除重启

最小化安装时 ks-account Init:1/2 问题 helm 版本 2.16.3 k8s版本 1.17.3,错误解决

  1. 操作步骤
    • kubectl get pvc --all-namespaces 查看有没有 openldap-pvc-openldap-0 或者 redis-pvc
    • helm status ks-openldap看看里边的资源是不是missing状态,是的话换个helm版本
    • 如果没有,去掉污点 更换 helm版本 可以尝试2.16.2版本 自己去github 尝试下载 搜索helm
    • 然后删掉openldap helm del --purge ks-openldap, 然后重启下ks-installer。kubectl delete pod ks-installer-xxxxxx-xxxxx -n kubesphere-system 这是删除ks的pod命令 删除后自动重启
    • 基本就可以解决了
      K8S集群搭建_第39张图片

安装后如何开启安装 DevOps 系统

安装后如何开启安装可插拔功能组件

#编辑 ks-installer 的pod 修改如下 想要开启其他类似的功能可自己根据情况开启,也可查看官网
kubectl edit cm -n kubesphere-system ks-installer
devops:
      enabled: True
      jenkinsMemoryLim: 2Gi
      jenkinsMemoryReq: 1500Mi
      jenkinsVolumeSize: 8Gi
      jenkinsJavaOpts_Xms: 512m
      jenkinsJavaOpts_Xmx: 512m
      jenkinsJavaOpts_MaxRAM: 2g
      sonarqube:
        enabled: True

保存退出,参考验证可插拔功能组件的安装 ,无需再次执行安装命令 ./install.sh,仅需通过查询 ks-installer 日志或 Pod 状态即可验证功能组件是否安装成功。

扩展pod错误日志检查

  1. 这些事件和日志通常都会有助于排查 Pod 发生的问题。
    https://baijiahao.baidu.com/s?id=1759795395470047800&wfr=spider&for=pc
    #查看pod的启动事件 如果pod不处于running状态可查看信息进行解决 默认都是在default上
    kubectl describe po pod名称 -n 命名空间
    #删除pod
    kubectl deletepo  pod pod名称
    #查看容器日志
    kubectl logs <pod-name> [-c <container-name>] 
    # 查看 Pod 的配置是否正确
    kubectl get pod <pod-name> -o yaml
    # 查看 Pod 的事件
    kubectl describe pod <pod-name>
    #获取 命名空间 kube-system 下的所有信息
    kubectl get all -n kube-system
    #删除其他命名空间下的部署信息
    kubectl delete -n kube-system deployment.apps/kubernetes-dashboard
    #编辑某个部署的yaml文件 保存退出后 即可自动重新部署
    kubectl edit deploy ks-account -n kubesphere-system
    #编辑某个pod的yaml 保存退出后 即可自动重新部署
    kubectl edit cm -n kubesphere-system ks-installer
    
  2. Pod 一直处于 Pending 状态
    • Pending 说明 Pod 还没有调度到某个 Node 上面。可以通过 kubectl describe pod 命令查看到当前 Pod 的事件,进而判断为什么没有调度。
  3. Pod 一直处于 Waiting 或 ContainerCreating 状态
    • 镜像拉取失败,比如配置了错误的镜像
    • Kubelet 无法访问镜像(国内环境访问 gcr.io 需要特殊处理)
    • 私有镜像的密钥配置错误
    • 镜像太大,拉取超时(可以适当调整 kubelet 的 --image-pull-progress-deadline 和 --runtime-request-timeout 选项)
    • CNI 网络错误,一般需要检查 CNI 网络插件的配置,比如
    • 无法配置 Pod 网络
    • 无法分配 IP 地址
    • 容器无法启动,需要检查是否打包了正确的镜像或者是否配置了正确的容器参数
  4. Pod 处于 ImagePullBackOff 状态
    • 这通常是镜像名称配置错误或者私有镜像的密钥配置错误导致。这种情况可以使用 docker pull 来验证镜像是否可以正常拉取。

7、kubesphere操作

  • 多租户管理快速入门
  • 创建 Wordpress 应用并发布至 Kubernetes
  • 基于Spring Boot项目构建流水线

你可能感兴趣的:(linux)