kubernetes常用命令 k8s指令大全

以下是 Kubernetes 常用命令的整理,涵盖集群管理、资源操作、调试排错等场景,帮助您快速掌握核心操作:

一、集群管理

命令 说明
kubectl cluster-info 查看集群信息
kubectl config get-contexts 列出所有上下文(集群配置)
kubectl config use-context <context-name> 切换集群或命名空间
kubectl get componentstatuses 检查集群组件状态(如 scheduler、controller-manager)

二、资源管理

通用操作
命令 说明
kubectl get <resource> 查看资源列表(如 pods, deployments, services
kubectl describe <resource> <name> 查看资源详细信息(事件、状态等)
kubectl create -f <file.yaml> 通过 YAML 文件创建资源
kubectl apply -f <file.yaml> 应用/更新资源配置
kubectl delete -f <file.yaml> 删除 YAML 中定义的资源
kubectl delete <resource> <name> 删除指定资源(如 pod/my-pod
kubectl edit <resource> <name> 直接编辑资源配置(实时生效)
常用资源别名
  • po: Pods
  • deploy: Deployments
  • svc: Services
  • ns: Namespaces
  • pv: PersistentVolumes
  • pvc: PersistentVolumeClaims

三、部署与扩缩容

命令 说明
kubectl scale deploy/<name> --replicas=3 扩展 Deployment 的副本数
kubectl rollout status deploy/<name> 查看部署状态(如滚动更新进度)
kubectl rollout history deploy/<name> 查看部署历史版本
kubectl rollout undo deploy/<name> 回滚到上一个版本
kubectl set image deploy/<name> <container>=<new-image> 更新容器镜像(触发滚动更新)

四、调试与日志

命令 说明
kubectl logs <pod-name> 查看 Pod 日志
kubectl logs -f <pod-name> 实时跟踪日志(类似 tail -f
kubectl exec -it <pod-name> -- /bin/sh 进入 Pod 的 Shell 环境
kubectl port-forward <pod-name> 8080:80 将 Pod 端口转发到本地(如访问服务)
kubectl top pod 查看 Pod 资源使用(需安装 metrics-server)
kubectl get events --sort-by=.metadata.creationTimestamp 查看集群事件(按时间排序)

五、网络与服务

命令 说明
kubectl expose deploy/<name> --port=80 --type=NodePort 创建 Service 暴露 Deployment
kubectl get endpoints <service-name> 查看 Service 关联的 Pod IP
kubectl get ingress 查看 Ingress 配置

六、配置与存储

命令 说明
kubectl get configmaps 查看所有 ConfigMap
kubectl get secrets 查看所有 Secret
kubectl create secret generic <name> --from-file=<key>=<path> 创建 Secret

七、高级操作

命令 说明
kubectl patch <resource> <name> -p '{"spec": {"replicas": 2}}' 部分更新资源配置
kubectl label <resource> <name> key=value 添加/修改标签
kubectl annotate <resource> <name> key=value 添加/修改注解
kubectl get <resource> -o yaml > file.yaml 导出资源配置到 YAML 文件
kubectl delete pod --force --grace-period=0 <pod-name> 强制删除 Pod(慎用)

八、插件与工具

命令 说明
kubectl krew install <plugin> 使用 Krew 安装插件(如 ctx, ns
kubectl helm install <chart> 通过 Helm 安装应用(需安装 Helm)

常用示例场景

  1. 快速创建 Pod

    复制代码
    kubectl run nginx --image=nginx --port=80
  2. 查看所有命名空间的 Pod

    复制代码
    kubectl get pods -A
  3. 查看特定标签的 Pod

    复制代码
    kubectl get pods -l app=web
  4. 调试启动失败的 Pod

    复制代码
    kubectl describe pod/<name>  # 查看错误原因
    kubectl logs <pod-name> -c <container-name>  # 查看指定容器日志
相关推荐
小时候的阳光15 小时前
Docker版Percona Xtrabackup全量压缩脚本
运维·docker·容器
生信大表哥15 小时前
单细胞测序分析(五)降维聚类&数据整合
linux·python·聚类·数信院生信服务器
“αβ”16 小时前
MySQL表的操作
linux·网络·数据库·c++·网络协议·mysql·https
神秘的土鸡16 小时前
openEuler 25.09 企业级 MySQL主从复制部署与性能优化实战提升50%
linux·数据库·mysql·性能优化·openeuler
知识分享小能手16 小时前
CentOS Stream 9入门学习教程,从入门到精通, CentOS Stream 9 命令行基础 —语法知识点与实战详解(4)
linux·学习·centos
哈里谢顿17 小时前
Kubernetes 节点污点(Taints)操作验证手册
kubernetes
菜萝卜子17 小时前
k8s 启动一个redis
redis·容器·kubernetes
音视频牛哥17 小时前
AI时代底层技术链:GPU、云原生与大模型的协同进化全解析
大数据·云原生·kubernetes·音视频·transformer·gpu算力·云原生cloud native
烤鱼骑不快17 小时前
linux 软Raid
linux
hhwyqwqhhwy18 小时前
Linux file->private
linux·运维·服务器