添加新节点
本教程演示了如何将新节点添加到单节点集群。若要水平扩展多节点集群,操作步骤基本相同。
您需要一个单节点集群。有关更多信息,请参见在 Linux 上以 All-in-One 模式安装 KubeSphere。
您需要已经。
使用 KubeKey 检索集群信息。以下命令会创建配置文件 ()。
备注
在配置文件中,将新节点的信息放在
hosts
和roleGroups
之下。该示例添加了两个新节点(即node1
和node2
)。这里的master1
是现有节点。···
spec:
hosts:
- {name: master1, address: 192.168.0.3, internalAddress: 192.168.0.3, user: root, password: [email protected]}
- {name: node1, address: 192.168.0.4, internalAddress: 192.168.0.4, user: root, password: [email protected]}
- {name: node2, address: 192.168.0.5, internalAddress: 192.168.0.5, user: root, password: [email protected]}
roleGroups:
etcd:
- master1
master:
- master1
worker:
- node1
- node2
···
备注
有关更多配置文件的信息,请参见编辑配置文件。
添加新节点时,请勿修改现有节点的主机名。
用自己的主机名替换示例中的主机名。
安装完成后,您将能够在 KubeSphere 的控制台上查看新节点及其信息。在集群管理页面,选择左侧菜单节点下的集群节点,或者执行命令
kubectl get node
以检查更改。NAME STATUS ROLES AGE VERSION
master1 Ready master,worker 20d v1.17.9
node1 Ready worker 31h v1.17.9
添加主节点的步骤与添加工作节点的步骤大体一致,不过您需要为集群配置负载均衡器。您可以使用任何云负载均衡器或者硬件负载均衡器(例如 F5)。另外,Keepalived 和 、或者 Nginx 也是创建高可用集群的替代方案。
使用 KubeKey 创建配置文件。
打开文件,可以看到一些字段预先填充了值。将新节点和负载均衡器的信息添加到文件中。以下示例供您参考:
apiVersion: kubekey.kubesphere.io/v1alpha1
kind: Cluster
metadata:
name: sample
spec:
hosts:
# You should complete the ssh information of the hosts
- {name: master1, address: 172.16.0.2, internalAddress: 172.16.0.2, user: root, password: Testing123}
- {name: master2, address: 172.16.0.5, internalAddress: 172.16.0.5, user: root, password: Testing123}
- {name: master3, address: 172.16.0.6, internalAddress: 172.16.0.6, user: root, password: Testing123}
- {name: worker1, address: 172.16.0.3, internalAddress: 172.16.0.3, user: root, password: Testing123}
- {name: worker2, address: 172.16.0.4, internalAddress: 172.16.0.4, user: root, password: Testing123}
- {name: worker3, address: 172.16.0.7, internalAddress: 172.16.0.7, user: root, password: Testing123}
roleGroups:
etcd:
- master1
- master2
- master3
master:
- master1
- master2
worker:
- worker1
- worker2
controlPlaneEndpoint:
# If loadbalancer is used, 'address' should be set to loadbalancer's ip.
domain: lb.kubesphere.local
address: 172.16.0.253
port: "6443"
kubernetes:
version: v1.21.5
imageRepo: kubesphere
clusterName: cluster.local
proxyMode: ipvs
masqueradeAll: false
maxPods: 110
nodeCidrMaskSize: 24
network:
plugin: calico
kubePodsCIDR: 10.233.64.0/18
kubeServiceCIDR: 10.233.0.0/18
registry:
privateRegistry: ""
请注意
controlPlaneEndpoint
字段。- 负载均衡器的域名默认为
lb.kubesphere.local
,用于内部访问。您可以按需进行更改。 - 大多数情况下,您需要为
address
字段提供负载均衡器的私有 IP 地址。然而,不同的云厂商可能为负载均衡器进行不同的配置。例如,如果您在阿里云上配置服务器负载均衡 (SLB),该平台会为 SLB 分配一个公共 IP 地址,这意味着您需要为address
字段指定公共 IP 地址。 port
字段指代api-server
的端口。
- 负载均衡器的域名默认为