# Kubernetes(K8s)使用攻略Kubernetes(通常缩写为K8s)是一个开源的容器编排平台,旨在自动化应用程序容器的部署、扩展和管理。它由Google发起,并成为云原生计算基金会(CNCF)的一个旗舰项目。本文将提供一份与K8s相关的使用攻略,涵盖其基本概念、部署、管理以及常见问题的解决方案。## 1. 基础概念### 1.1 Pods
Pod是K8s的基本执行单元,通常一个Pod会包含一个或多个紧密耦合的容器,这些容器共享存储和网络资源。### 1.2 服务(Service)
服务是一种抽象,定义了一组Pod的访问策略,即使Pod的后端实例发生变化,用户依然可以稳定地访问应用程序。### 1.3 控制器(Controller)
控制器负责管理Pod的状态,确保系统中的实际状态与期望状态相匹配。常用的控制器有Deployment、StatefulSet、DaemonSet等。### 1.4 节点(Node)
节点是K8s集群的工作负载运行的地方,可以是物理机也可以是虚拟机。## 2. 环境准备在开始使用K8s之前,你需要一些基本的环境准备:### 2.1 安装kubectl
`kubectl`是K8s的命令行工具,可以用来管理K8s集群。可以通过以下命令安装:```bash
curl -LO "https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl"
chmod +x ./kubectl
sudo mv ./kubectl /usr/local/bin/kubectl
```### 2.2 部署K8s集群
你可以使用Minikube在本地快速部署一个K8s集群,或者在云平台(如AWS、GCP、Azure等)上使用Kubernetes服务。```bash
minikube start
```## 3. 部署应用### 3.1 创建Deployment
一个Deployment用于管理Pod的部署及更新,以下是一个创建Deployment的示例(`nginx-deployment.yaml`):```yaml
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:latest
ports:
- containerPort: 80
```使用以下命令部署:```bash
kubectl apply -f nginx-deployment.yaml
```### 3.2 创建服务
通过以下YAML文件(`nginx-service.yaml`)创建一个ClusterIP类型的服务来暴露我们的Nginx应用:```yaml
apiVersion: v1
kind: Service
metadata:
name: nginx-service
spec:
selector:
app: nginx
ports:
- protocol: TCP
port: 80
targetPort: 80
```使用以下命令创建服务:```bash
kubectl apply -f nginx-service.yaml
```## 4. 日常管理### 4.1 监测Pod状态
使用以下命令查看Pod的状态:```bash
kubectl get pods
```### 4.2 日志查看
查看Pod日志:```bash
kubectl logs