rancher server 单节点部署/K8S高可用部署

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了rancher server 单节点部署/K8S高可用部署相关的知识,希望对你有一定的参考价值。

环境说明:
#  操作系统:centos7 
#  docker版本:19.03.5
# rancher版本: latest
#  rancher server 节点IP :192.168.2.175
# rancher agent节点IP: 192.168.2.175,192.168.2.176,192.168.2.177,192.168.2.185,192.168.2.187
# K8S master 节点IP:192.168.2.176,192.168.2.177,192.168.2.185
# K8S worker节点IP: 192.168.2.175,192.168.2.176,192.168.2.177,192.168.2.185,192.168.2.187
# K8S etcd 节点IP:192.168.2.176,192.168.2.177,192.168.2.185

部署准备:

# 操作在所有节点进行
# 修改内核参数:
关闭swap
 vim /etc/sysctl.conf
 vm.swappiness=0
 net.ipv4.ip_forward = 1
 net.bridge.bridge-nf-call-ip6tables = 1
 net.bridge.bridge-nf-call-iptables = 1
 sysctl -p
 临时生效
 swapoff -a && sysctl -w vm.swappiness=0
 # 修改 fstab 不在挂载 swap
 vi /etc/fstab
# /dev/mapper/centos-swap swap                    swap    defaults        0 0
# 安装docker
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 添加docker配置
mkdir -p /etc/docker
vim /etc/docker/daemon.json
{
    "max-concurrent-downloads": 20,
    "data-root": "/apps/docker/data",
    "exec-root": "/apps/docker/root",
    "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"],
    "log-driver": "json-file",
    "bridge": "docker0",
    "oom-score-adjust": -1000,
    "debug": false,
    "log-opts": {
        "max-size": "100M",
        "max-file": "10"
    },
    "default-ulimits": {
        "nofile": {
            "Name": "nofile",
            "Hard": 1024000,
            "Soft": 1024000
        },
        "nproc": {
            "Name": "nproc",
            "Hard": 1024000,
            "Soft": 1024000
        },
       "core": {
            "Name": "core",
            "Hard": -1,
            "Soft": -1
      }

    }
}

# 安装依赖
 yum install -y   yum-utils  ipvsadm  telnet  wget  net-tools  conntrack  ipset  jq  iptables  curl  sysstat  libseccomp  socat  nfs-utils  fuse  fuse-devel 
# 安装docker依赖
 yum install -y    python-pip python-devel yum-utils device-mapper-persistent-data lvm2
 # 安装docker 
yum install -y docker-ce
# reload service 配置
 systemctl daemon-reload
# 重启docker
 systemctl restart docker
# 设置开机启动
systemctl enable docker

部署rancher server

# 操作IP: 192.168.2.175
docker run -d --restart=unless-stopped   -p 80:80 -p 443:443   rancher/rancher:latest
# 等待镜像拉取完成启动好容器
打开浏览器输入:192.168.2.175 浏览器会自动跳转到https选择 继续前往192.168.2.175(不安全)

技术图片

设置 rancher server

技术图片
设置好密码单击继续
技术图片
单击保存url

部署K8S 集群

技术图片
单击全局 选择添加集群

技术图片
选择自定义
技术图片
根据自己需求配置集群名集群参数
技术图片
选择编辑yaml 可以配置一些集群参数
技术图片
配置 kube-proxy 数据转发模式 这里我修改为IPVS 模式当然如果默认是iptables 配置完成选择下一步

启动 rancher agent

技术图片

# 在192.168.2.176,192.168.2.177,192.168.2.185 节点运行
docker run -d --privileged --restart=unless-stopped --net=host -v /etc/kubernetes:/etc/kubernetes -v /var/run:/var/run rancher/rancher-agent:v2.3.5 --server https://192.168.2.175 --token 8ps9xfssqz6vxbd6ltclztfvfk2k7794vnj42gpg94kjd82782jjlv --ca-checksum c8e7cce16152862434f78402031590b51a3975ec3a43a7d2c4660e05358eefd2 --etcd --controlplane --worker

技术图片

# 在 192.168.2.175,192.168.2.187 运行
docker run -d --privileged --restart=unless-stopped --net=host -v /etc/kubernetes:/etc/kubernetes -v /var/run:/var/run rancher/rancher-agent:v2.3.5 --server https://192.168.2.175 --token 8ps9xfssqz6vxbd6ltclztfvfk2k7794vnj42gpg94kjd82782jjlv --ca-checksum c8e7cce16152862434f78402031590b51a3975ec3a43a7d2c4660e05358eefd2 --worker

技术图片
所有节点添加完成 选择完成按钮
技术图片
技术图片
等待集群部署完成
技术图片
技术图片
集群已经正常

部署监控

技术图片
部署监控前
技术图片
监控部署完成
技术图片

远程操作K8S 集群配置

选择 kubeconfig 单击打开
技术图片
选择复制到剪贴板然后选择关闭
技术图片

打开文本编辑器我使用的Notepad++
技术图片
另存为 config 文件

kubectl 使用 config

# win10 on linux
# 文件路径根据自己配置文件修改 你也可以放到默认路径 ~/.kube/config 这样就不用指定kubeconfig kubectl 默认使用
 export kubeconfig=/mnt/g/work/rke/config
# 查看启动所有POD
kubectl --kubeconfig=$kubeconfig get pod -A -o wide
root@Qist:~# kubectl --kubeconfig=$kubeconfig get pod -A -o wide
NAMESPACE           NAME                                                       READY   STATUS             RESTARTS   AGE    IP              NODE    NOMINATED NODE   READINESS GATES
cattle-prometheus   exporter-kube-state-cluster-monitoring-6db64f7d4b-hf6gp    1/1     Running            0          125m   10.42.3.4       2-187   <none>           <none>
cattle-prometheus   exporter-node-cluster-monitoring-b9q4k                     1/1     Running            0          125m   192.168.2.175   2-175   <none>           <none>
cattle-prometheus   exporter-node-cluster-monitoring-d7v9w                     1/1     Running            0          125m   192.168.2.187   2-187   <none>           <none>
cattle-prometheus   exporter-node-cluster-monitoring-f686h                     1/1     Running            0          125m   192.168.2.177   2-177   <none>           <none>
cattle-prometheus   exporter-node-cluster-monitoring-t9hbx                     1/1     Running            0          125m   192.168.2.176   2-176   <none>           <none>
cattle-prometheus   exporter-node-cluster-monitoring-tw9n7                     1/1     Running            0          125m   192.168.2.185   2-185   <none>           <none>
cattle-prometheus   grafana-cluster-monitoring-65cbc8749-xddfd                 2/2     Running            0          125m   10.42.3.3       2-187   <none>           <none>
cattle-prometheus   prometheus-cluster-monitoring-0                            5/5     Running            1          125m   10.42.2.2       2-175   <none>           <none>
cattle-prometheus   prometheus-operator-monitoring-operator-5b66559965-4lkvv   1/1     Running            0          125m   10.42.3.2       2-187   <none>           <none>
cattle-system       cattle-cluster-agent-748d9f6bf6-zgk4x                      1/1     Running            0          132m   10.42.0.6       2-176   <none>           <none>
cattle-system       cattle-node-agent-f2szj                                    1/1     Running            0          128m   192.168.2.185   2-185   <none>           <none>
cattle-system       cattle-node-agent-h2hgv                                    1/1     Running            0          130m   192.168.2.177   2-177   <none>           <none>
cattle-system       cattle-node-agent-p2t72                                    1/1     Running            0          129m   192.168.2.187   2-187   <none>           <none>
cattle-system       cattle-node-agent-wnqg5                                    1/1     Running            0          132m   192.168.2.176   2-176   <none>           <none>
cattle-system       cattle-node-agent-zsvvt                                    1/1     Running            0          129m   192.168.2.175   2-175   <none>           <none>
cattle-system       kube-api-auth-ddnpp                                        1/1     Running            0          130m   192.168.2.177   2-177   <none>           <none>
cattle-system       kube-api-auth-h9mtw                                        1/1     Running            0          132m   192.168.2.176   2-176   <none>           <none>
cattle-system       kube-api-auth-wbz96                                        1/1     Running            0          127m   192.168.2.185   2-185   <none>           <none>
ingress-nginx       default-http-backend-67cf578fc4-tn4jk                      1/1     Running            0          132m   10.42.0.5       2-176   <none>           <none>
ingress-nginx       nginx-ingress-controller-7dr8g                             0/1     CrashLoopBackOff   30         129m   192.168.2.175   2-175   <none>           <none>
ingress-nginx       nginx-ingress-controller-gcwhl                             1/1     Running            0          129m   192.168.2.187   2-187   <none>           <none>
ingress-nginx       nginx-ingress-controller-hxmpb                             1/1     Running            0          130m   192.168.2.177   2-177   <none>           <none>
ingress-nginx       nginx-ingress-controller-msbw7                             1/1     Running            0          127m   192.168.2.185   2-185   <none>           <none>
ingress-nginx       nginx-ingress-controller-nlhsl                             1/1     Running            0          132m   192.168.2.176   2-176   <none>           <none>
kube-system         coredns-7c5566588d-4ng4f                                   1/1     Running            0          133m   10.42.0.2       2-176   <none>           <none>
kube-system         coredns-7c5566588d-q695x                                   1/1     Running            0          130m   10.42.1.2       2-177   <none>           <none>
kube-system         coredns-autoscaler-65bfc8d47d-gnns8                        1/1     Running            0          133m   10.42.0.3       2-176   <none>           <none>
kube-system         kube-flannel-cz6kh                                         2/2     Running            1          130m   192.168.2.177   2-177   <none>           <none>
kube-system         kube-flannel-dtslx                                         2/2     Running            2          129m   192.168.2.187   2-187   <none>           <none>
kube-system         kube-flannel-j7lrd                                         2/2     Running            0          128m   192.168.2.185   2-185   <none>           <none>
kube-system         kube-flannel-jm6v8                                         2/2     Running            0          133m   192.168.2.176   2-176   <none>           <none>
kube-system         kube-flannel-n8f82                                         2/2     Running            2          129m   192.168.2.175   2-175   <none>           <none>
kube-system         metrics-server-6b55c64f86-rxjjt                            1/1     Running            0          133m   10.42.0.4       2-176   <none>           <none>
kube-system         rke-coredns-addon-deploy-job-2c5l2                         0/1     Completed          0          133m   192.168.2.176   2-176   <none>           <none>
kube-system         rke-ingress-controller-deploy-job-5scd5                    0/1     Completed          0          132m   192.168.2.176   2-176   <none>           <none>
kube-system         rke-metrics-addon-deploy-job-7dkc6                         0/1     Completed          0          133m   192.168.2.176   2-176   <none>           <none>
kube-system         rke-network-plugin-deploy-job-2qxj5                        0/1     Completed          0          133m   192.168.2.176   2-176   <none>           <none>
# 查看K8S 集群状态
root@Qist:~# kubectl --kubeconfig=$kubeconfig get cs
NAME                 STATUS    MESSAGE             ERROR
scheduler            Healthy   ok
controller-manager   Healthy   ok
etcd-2               Healthy   {"health":"true"}
etcd-1               Healthy   {"health":"true"}
etcd-0               Healthy   {"health":"true"}
# 查看所有node
root@Qist:~# kubectl --kubeconfig=$kubeconfig get node -o wide
NAME    STATUS   ROLES                      AGE    VERSION   INTERNAL-IP     EXTERNAL-IP   OS-IMAGE                KERNEL-VERSION                CONTAINER-RUNTIME
2-175   Ready    worker                     131m   v1.17.2   192.168.2.175   <none>        CentOS Linux 7 (Core)   3.10.0-1062.12.1.el7.x86_64   docker://19.3.5
2-176   Ready    controlplane,etcd,worker   135m   v1.17.2   192.168.2.176   <none>        CentOS Linux 7 (Core)   3.10.0-1062.12.1.el7.x86_64   docker://19.3.5
2-177   Ready    controlplane,etcd,worker   132m   v1.17.2   192.168.2.177   <none>        CentOS Linux 7 (Core)   3.10.0-1062.12.1.el7.x86_64   docker://19.3.5
2-185   Ready    controlplane,etcd,worker   129m   v1.17.2   192.168.2.185   <none>        CentOS Linux 7 (Core)   3.10.0-1062.12.1.el7.x86_64   docker://19.3.5
2-187   Ready    worker                     131m   v1.17.2   192.168.2.187   <none>        CentOS Linux 7 (Core)   3.10.0-1062.12.1.el7.x86_64   docker://19.3.5

最后说明:

# 由于192.168.2.175 部署rancher server 占用80 443 端口所以 nginx-ingress-controller 部署不会成功
你可以修改nginx-ingress-controller 让它不部署到 rancher server
k8s master 单节点部署请选择一个节点部署时选择 controlplane etcd 等

以上是关于rancher server 单节点部署/K8S高可用部署的主要内容,如果未能解决你的问题,请参考以下文章

rke高可用部署K8S集群及rancher server 高可用

使用Rancher Server部署本地多节点K8S集群

如何将Rancher 2.1.x 从单节点安装迁移到高可用安装

rancher部署k8s遇到的问题总结

K8S集群中部署 Rancher 2.5

rancher三节点k8s集群部署例子