对于刚开始学习 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!