Kubernetes 是一个开源的容器编排平台,用于自动化应用程序的部署、扩展和管理。它提供了一个强大的工具集,帮助开发者和运维团队管理容器化应用程序的生命周期。本文将详细介绍如何从零开始搭建一个 Kubernetes 集群,包括准备工作、安装 Docker、安装 Kubernetes 组件、配置网络插件、验证集群以及部署应用。
在开始搭建 Kubernetes 集群之前,我们需要确保所有节点满足一定的硬件和软件要求,并且网络配置正确。
Kubernetes 使用 Docker 作为容器运行时环境,因此首先需要在所有节点上安装 Docker。
sudo apt-get update sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" sudo apt-get update sudo apt-get install -y docker-ce sudo systemctl start docker sudo systemctl enable docker sudo docker --version 在所有节点上安装 Kubernetes 组件,包括 kubeadm、kubelet 和 kubectl。
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add - sudo apt-add-repository "deb http://apt.kubernetes.io/ kubernetes-xenial main" sudo apt-get update sudo apt-get install -y kubelet kubeadm kubectl sudo apt-mark hold kubelet kubeadm kubectl 在 Master 节点上执行以下命令来初始化 Kubernetes 集群:
sudo kubeadm init --pod-network-cidr=192.168.0.0/16 注意:--pod-network-cidr 参数指定了 Pod 网络的 CIDR 范围,这里使用 Calico 的默认 CIDR。
kubeadm join <Master-Node-IP>:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash> mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config kubectl get nodes 输出应显示 Master 节点的状态为 NotReady,这是因为尚未安装网络插件。
在每个 Worker 节点上执行以下命令,将其加入 Kubernetes 集群:
kubeadm join 命令加入集群: sudo kubeadm join <Master-Node-IP>:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash> kubectl get nodes 输出应显示所有节点的状态为 NotReady,这是因为尚未安装网络插件。
Kubernetes 需要一个网络插件来管理 Pod 之间的通信。常用的网络插件有 Calico、Flannel 等。本文将使用 Calico 作为网络插件。
kubectl apply -f https://docs.projectcalico.org/v3.14/manifests/calico.yaml kubectl get pods -n kube-system 输出应显示 Calico 相关的 Pod 状态为 Running。
kubectl get nodes 输出应显示所有节点的状态为 Ready。
在完成所有步骤后,我们需要验证 Kubernetes 集群是否正常运行。
kubectl get nodes 输出应显示所有节点的状态为 Ready。
kubectl get componentstatuses 输出应显示所有组件的状态为 Healthy。
kubectl create deployment nginx --image=nginx kubectl expose deployment nginx --port=80 --type=NodePort kubectl get pods 输出应显示 Nginx Pod 的状态为 Running。
kubectl get svc nginx 输出应显示 Nginx 服务的 NodePort,通过浏览器访问 <Node-IP>:<NodePort> 应能看到 Nginx 的欢迎页面。
在 Kubernetes 集群中部署应用通常涉及创建 Deployment 和 Service 资源。以下是一个简单的示例,展示如何部署一个 Nginx 应用。
apiVersion: apps/v1 kind: Deployment metadata: name: nginx-deployment spec: replicas: 3 selector: matchLabels: app: nginx template: metadata: labels: app: nginx spec: containers: - name: nginx image: nginx:1.14.2 ports: - containerPort: 80 保存为 nginx-deployment.yaml,然后执行:
kubectl apply -f nginx-deployment.yaml apiVersion: v1 kind: Service metadata: name: nginx-service spec: selector: app: nginx ports: - protocol: TCP port: 80 targetPort: 80 type: NodePort 保存为 nginx-service.yaml,然后执行:
kubectl apply -f nginx-service.yaml kubectl get pods kubectl get svc 通过浏览器访问 <Node-IP>:<NodePort> 应能看到 Nginx 的欢迎页面。
本文详细介绍了如何从零开始搭建一个 Kubernetes 集群,包括准备工作、安装 Docker、安装 Kubernetes 组件、配置网络插件、验证集群以及部署应用。通过本文的步骤,您可以成功搭建一个 Kubernetes 集群,并在其上部署和管理容器化应用程序。Kubernetes 提供了强大的工具集,帮助您自动化应用程序的部署、扩展和管理,是现代云原生应用开发的重要基础设施。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。