linux

Linux下Kubernetes集群怎么搭建

小樊
49
2025-09-29 10:32:45
栏目: 智能运维

Linux下搭建Kubernetes集群详细步骤

1. 准备工作

在开始搭建前,需完成以下基础配置,确保所有节点(Master/Worker)环境一致:

2. 安装Docker容器运行时

Kubernetes依赖容器运行时管理容器,推荐使用Docker(也可选containerd):

3. 安装Kubernetes核心组件(kubeadm、kubelet、kubectl)

Kubeadm用于集群初始化,kubelet管理节点上的容器,kubectl用于命令行操作:

4. 初始化Master节点

Master节点是集群的控制平面,负责调度、API服务等核心功能:

sudo kubeadm init \
  --pod-network-cidr=10.244.0.0/16 \  # 指定Pod网络CIDR(需与后续网络插件匹配)
  --apiserver-advertise-address=<Master-IP> \  # Master节点IP
  --image-repository registry.aliyuncs.com/google_containers  # 使用国内镜像加速

初始化完成后,会输出关键信息

5. 部署网络插件

Kubernetes需要网络插件实现Pod间通信,常用插件:

验证网络插件是否运行:kubectl get pods -n kube-system(所有Pod应为Running状态)。

6. 加入Worker节点

在Worker节点上执行Master节点初始化时输出的kubeadm join命令(替换为实际IP、Token和Hash):

sudo kubeadm join <Master-IP>:6443 \
  --token <token> \
  --discovery-token-ca-cert-hash sha256:<hash>

若忘记命令,可在Master节点上重新生成:kubeadm token create --print-join-command

7. 验证集群状态

在Master节点上执行以下命令,确认集群正常运行:

kubectl get nodes  # 查看节点状态,应为"Ready"
kubectl get pods -A  # 查看所有命名空间的Pod状态,应为"Running"

若节点未就绪,可等待几分钟或查看Pod日志排查问题:kubectl describe pod <pod-name> -n kube-system

8. 可选:部署Kubernetes Dashboard(可视化工具)

Dashboard提供Web界面管理集群,部署步骤:

kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.7.0/aio/deploy/recommended.yaml

创建管理员账号(用于登录Dashboard):

kubectl create serviceaccount dashboard-admin-sa
kubectl create clusterrolebinding dashboard-admin-sa --clusterrole=cluster-admin --serviceaccount=default:dashboard-admin-sa

获取登录Token:

kubectl -n default get secret $(kubectl -n default get sa dashboard-admin-sa -o jsonpath="{.secrets[0].name}") -o go-template="{{.data.token | base64decode}}"

访问Dashboard:通过kubectl proxy启动代理,然后在浏览器输入http://localhost:8001/api/v1/namespaces/kubernetes-dashboard/services/https:kubernetes-dashboard:/proxy/,粘贴Token登录。

以上步骤完成后,一个基本的Kubernetes集群已搭建完成,可根据需求部署应用(如kubectl create deployment nginx --image=nginx)。

0
看了该问题的人还看了