Kubernetes(K8S)是一款开源的容器编排引擎,能够自动化地部署、扩展和管理容器化的应用程序。在实际应用场景中,我们通常会使用多台服务器来搭建一个K8S集群,以实现高可用性和负载均衡。在本文中,我将向你展示如何在两台服务器上搭建一个简单的K8S集群。

下面是整个搭建K8S集群的步骤概览:

| 步骤 | 操作 |
|----------------|------------------------------------------------------------------|
| 步骤一:准备两台服务器 | 在两台服务器上安装操作系统,并配置好网络连接。 |
| 步骤二:在两台服务器上安装Docker | 在每台服务器上安装Docker引擎,用于运行容器。 |
| 步骤三:在两台服务器上安装K8S组件 | 分别在两台服务器上安装K8S的Master和Node组件。 |
| 步骤四:初始化K8S集群 | 在Master节点执行初始化命令,将Node节点加入集群。 |
| 步骤五:部署一个简单的应用程序 | 在K8S集群上部署一个简单的Nginx应用程序,验证集群是否正常工作。 |

现在让我们逐步来看每个步骤需要做的操作以及相应的代码示例。

### 步骤一:准备两台服务器
首先,你需要准备两台运行Linux操作系统的服务器,并确保它们可以相互通信。假设它们的IP地址分别为192.168.1.1和192.168.1.2。

### 步骤二:在两台服务器上安装Docker
在每台服务器上执行以下命令来安装Docker:
```bash
$ sudo apt-get update
$ sudo apt-get install docker.io
```

### 步骤三:在两台服务器上安装K8S组件
在Master节点(192.168.1.1)上执行以下命令来安装K8S Master组件:
```bash
$ 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
```

在Node节点(192.168.1.2)上执行以下命令来安装K8S Node组件:
```bash
$ 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

### 步骤四:初始化K8S集群
在Master节点(192.168.1.1)上执行以下命令来初始化K8S集群:
```bash
$ sudo kubeadm init --apiserver-advertise-address=192.168.1.1 --pod-network-cidr=192.168.0.0/16
```

在Node节点(192.168.1.2)上执行初始化命令输出的加入集群的命令。

### 步骤五:部署一个简单的应用程序
你可以使用以下YAML文件来部署一个简单的Nginx应用程序:
```yaml
apiVersion: v1
kind: Pod
metadata:
name: nginx-app
spec:
containers:
- name: nginx
image: nginx:latest
```

将上述内容保存为`nginx-app.yaml`,然后在K8S集群上执行以下命令来部署应用程序:
```bash
$ kubectl apply -f nginx-app.yaml
```

最后,你可以通过访问Nginx服务的ClusterIP来验证应用程序是否正常部署。

通过以上步骤,你已经成功在两台服务器上搭建了一个简单的K8S集群,并成功部署了一个Nginx应用程序。希望这篇文章对你有所帮助,让你能够更好地理解如何在多台服务器上搭建K8S集群。如果有任何疑问,欢迎随时向我提问!