Kubernetes (K8S) 是一个开源的容器编排平台,它可以帮助我们管理和运行容器化应用程序。本文将教会新手如何安装 K8S,并提供相应的代码示例。

## 安装 K8S 的流程

下面是安装 K8S 的步骤,让我们逐步进行:

| 步骤 | 描述 |
| ---- | ---- |
| 1 | 配置环境 |
| 2 | 安装 Docker |
| 3 | 安装 kubeadm, kubelet 和 kubectl |
| 4 | 初始化 master 节点 |
| 5 | 加入 worker 节点 |

下面我们将逐步介绍每个步骤所需的操作和代码示例。

### 步骤 1: 配置环境

在开始安装之前,我们需要确保系统满足一些配置要求。首先,操作系统应该是 Linux,并且具备一定的计算和网络资源。其次,关闭防火墙和交换分区。最后,确保节点之间能够相互通信。

### 步骤 2: 安装 Docker

Docker 是一个非常流行的容器引擎,可以帮助我们构建、打包和运行应用程序。以下是在 Linux 系统安装 Docker 的代码示例:

```shell
# 添加 Docker 官方的 GPG 密钥
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

# 添加 Docker 的 APT 仓库
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"

# 更新 APT 软件包索引
sudo apt-get update

# 安装 Docker CE
sudo apt-get install -y docker-ce
```

### 步骤 3: 安装 kubeadm, kubelet 和 kubectl

kubeadm 是一个用于部署和管理 Kubernetes 集群的工具,kubelet 是运行在每个节点上的代理,负责管理容器的生命周期。kubectl 是 Kubernetes 的命令行工具,用于与集群进行交互。以下是安装 kubeadm, kubelet 和 kubectl 的代码示例:

```shell
# 添加 Kubernetes 的 APT 仓库
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee -a /etc/apt/sources.list.d/kubernetes.list

# 更新 APT 软件包索引
sudo apt-get update

# 安装 kubeadm, kubelet 和 kubectl
sudo apt-get install -y kubelet kubeadm kubectl

# 防止软件包自动更新
sudo apt-mark hold kubelet kubeadm kubectl
```

### 步骤 4: 初始化 master 节点

在 K8S 中,master 节点负责管理集群状态和调度工作。以下是初始化 master 节点的代码示例:

```shell
# 初始化 master 节点
sudo kubeadm init --pod-network-cidr=10.244.0.0/16

# 完成初始化后,根据输出的信息执行以下命令
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

# 安装网络插件 (这里以 Calico 为例)
kubectl apply -f https://docs.projectcalico.org/v3.11/manifests/calico.yaml
```

在初始化过程中,会输出一些重要的信息,如 join 命令和网络插件的安装命令。请根据实际情况保存这些信息,以便稍后使用。

### 步骤 5: 加入 worker 节点

除了 master 节点外,Kubernetes 集群还包括一个或多个 worker 节点,负责运行应用程序的容器。以下是将 worker 节点加入到集群的代码示例:

```shell
# 在 worker 节点上执行以下命令
sudo kubeadm join : --token --discovery-token-ca-cert-hash
```

其中,`:` 是 master 节点的 IP 地址和端口,`` 是初始化 master 节点时生成的令牌,`` 是证书的哈希值。这些值可以在初始化 master 节点时的输出中找到。

通过执行上述命令,在 worker 节点上加入到集群后,你就成功安装了K8S。

希望通过这篇文章的指导,新手可以快速了解到如何安装 K8S,并成功地将应用程序部署到 K8S 集群中。当然,K8S 的使用远不止这些,你可以继续深入学习,了解更多关于 K8S 的知识和技术。