5分钟上手 Kubernetes:精简实用的 Kubectl 命令速查宝典!

对于刚开始学习 Kubernetes 的人来说,理解和掌握 kubectl 命令是入门的第一步。kubectl 是 Kubernetes 的命令行工具,用于管理 Kubernetes 集群中的资源。在这篇文章中,我们将总结一些最常用的 kubectl 命令,通过简明的介绍和示例,让你在 5 分钟内快速上手 Kubernetes,优雅地开始使用 K8s!

1. 配置与基本信息查询

1.1 设置 Kubernetes 上下文

kubectl 依赖配置文件来连接和管理集群。默认配置文件位于 ~/.kube/config

# 查看当前上下文
kubectl config current-context

# 设置新的上下文(例如:切换到生产环境)
kubectl config use-context <context-name>

通过正确的上下文配置,你可以轻松切换到不同的集群环境,如测试集群、生产集群等。

1.2 获取节点信息

在 Kubernetes 中,节点是运行 Pods 的物理或虚拟机。以下命令可以帮助你查看集群中所有节点的状态。

# 查看所有节点的信息
kubectl get nodes

# 查看节点详细信息
kubectl describe node <node-name>

2. 资源查看与管理

2.1 查看 Pods

Pod 是 Kubernetes 中的最小部署单元,通常包含一个或多个容器。

# 查看所有命名空间中的 Pods
kubectl get pods --all-namespaces

# 查看特定命名空间中的 Pods
kubectl get pods -n <namespace>

# 查看 Pod 的详细信息
kubectl describe pod <pod-name>

2.2 部署(Deployment)管理

Deployment 是用于管理 Pod 的 Kubernetes 资源,支持滚动更新和回滚。

# 查看所有部署
kubectl get deployments

# 查看特定命名空间中的部署
kubectl get deployments -n <namespace>

# 部署一个应用(例如 Nginx)
kubectl create deployment nginx --image=nginx

# 更新 Deployment 的镜像版本
kubectl set image deployment/nginx nginx=nginx:1.16.1

# 删除 Deployment
kubectl delete deployment nginx

2.3 服务(Service)管理

Service 是 Kubernetes 中的网络资源,用于暴露一组 Pods,并提供负载均衡。

# 查看所有服务
kubectl get services

# 暴露 Deployment 创建一个 Service(例如 NodePort 类型)
kubectl expose deployment nginx --port=80 --type=NodePort

# 查看特定 Service 的详细信息
kubectl describe service nginx

# 删除 Service
kubectl delete service nginx

3. 日志和调试

3.1 查看 Pod 日志

在开发和调试过程中,查看 Pod 的日志非常重要。可以使用 kubectl logs 命令来获取容器日志。

# 查看单个容器的日志
kubectl logs <pod-name>

# 如果 Pod 中有多个容器,指定容器名查看日志
kubectl logs <pod-name> -c <container-name>

# 实时流式查看日志
kubectl logs -f <pod-name>

3.2 进入 Pod 内部执行命令

在调试时,有时需要进入 Pod 内部执行命令,可以使用 kubectl exec 进入容器。

# 进入 Pod 内部
kubectl exec -it <pod-name> -- /bin/sh

# 运行一个命令,例如查看 Pod 内部的文件
kubectl exec <pod-name> -- cat /etc/hostname

3.3 查看集群事件

Kubernetes 会记录集群中发生的事件,例如 Pod 的创建、调度失败等,这对于故障排查非常有用。

# 查看所有事件
kubectl get events

# 按时间排序事件
kubectl get events --sort-by='.metadata.creationTimestamp'

4. 配置管理

4.1 创建与管理 ConfigMap

ConfigMap 用于存储配置信息,可以将它们加载到容器中作为环境变量或配置文件。

# 从键值对创建 ConfigMap
kubectl create configmap my-config --from-literal=key1=value1 --from-literal=key2=value2

# 查看所有 ConfigMap
kubectl get configmaps

# 查看 ConfigMap 详细信息
kubectl describe configmap my-config

4.2 创建与管理 Secret

Secret 用于存储敏感信息,例如密码、OAuth 令牌等。

# 创建 Secret
kubectl create secret generic my-secret --from-literal=password=my-password

# 查看所有 Secret
kubectl get secrets

# 查看 Secret 详细信息
kubectl describe secret my-secret

5. 资源扩展和更新

5.1 扩展 Deployment

当流量增加时,可以轻松扩展应用的副本数以满足需求。

# 扩展 Deployment 的副本数
kubectl scale deployment nginx --replicas=3

5.2 滚动更新

滚动更新允许你在不中断服务的情况下更新应用。

# 更新 Deployment 的镜像版本
kubectl set image deployment/nginx nginx=nginx:1.17.0

# 查看更新进度
kubectl rollout status deployment/nginx

5.3 回滚更新

如果新的 Deployment 版本出现问题,可以快速回滚。

# 查看更新历史
kubectl rollout history deployment/nginx

# 回滚到上一个版本
kubectl rollout undo deployment/nginx

6. 清理资源

最后,不再使用的资源可以通过以下命令删除,以释放集群资源。

# 删除 Pod
kubectl delete pod <pod-name>

# 删除 Deployment
kubectl delete deployment nginx

# 删除 Service
kubectl delete service nginx

结语

以上就是 Kubernetes 中常用 kubectl 命令的总结。这些命令涵盖了日常的集群管理和应用操作,如查看资源、部署应用、调试和更新等。通过这些命令,你可以快速上手 Kubernetes 的基本操作,优雅地管理 Kubernetes 集群中的应用。希望这篇文章能帮助你快速熟悉 Kubernetes!

本文由博客一文多发平台 OpenWrite 发布!

KubeSphere
124 声望55 粉丝

KubeSphere 是一个开源的以应用为中心的容器管理平台,支持部署在任何基础设施之上,并提供简单易用的 UI,极大减轻日常开发、测试、运维的复杂度,旨在解决 Kubernetes 本身存在的存储、网络、安全和易用性等痛...