对于刚开始学习 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!
2024-11-01
2024-10-16
2024-10-18
KubeSphere (https://kubesphere.io)是在 Kubernetes 之上构建的开源容器平台,提供全栈的 IT 自动化运维的能力,简化企业的 DevOps 工作流。
KubeSphere 已被 Aqara 智能家居、本来生活、东方通信、微宏科技、东软、华云、新浪、三一重工、华夏银行、四川航空、国药集团、微众银行、紫金保险、去哪儿网、中通、中国人民银行、中国银行、中国人保寿险、中国太平保险、中国移动、中国联通、中国电信、天翼云、中移金科、Radore、ZaloPay 等海内外数万家企业采用。KubeSphere 提供了开发者友好的向导式操作界面和丰富的企业级功能,包括 Kubernetes 多云与多集群管理、DevOps (CI/CD)、应用生命周期管理、边缘计算、微服务治理 (Service Mesh)、多租户管理、可观测性、存储与网络管理、GPU support 等功能,帮助企业快速构建一个强大和功能丰富的容器云平台。
文章转载自KubeSphere云原生。点击这里阅读原文了解更多。
CNCF概况(幻灯片)
扫描二维码联系我们!
CNCF (Cloud Native Computing Foundation)成立于2015年12月,隶属于Linux Foundation,是非营利性组织。
CNCF(云原生计算基金会)致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。我们通过将最前沿的模式民主化,让这些创新为大众所用。请关注CNCF微信公众号。