k8s基础命令集合

1、集群信息

bash 复制代码
# 显示k8s客户端和服务器版本
kubectl version

# 显示当前上下文信息
kubectl config current-context

# 切换上下文
kubectl config use-context <context-name>

# 列出所有上下文
kubectl config get-contexts

# 获取集群信息
kubectl cluster-info

2、节点管理

bash 复制代码
# 列出所有节点
kubectl get nodes

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

3、命名空间管理

bash 复制代码
# 列出所有命名空间
kubectl get namespaces

# 创建命名空间
kubectl create namespace <namespace-name>

# 删除命名空间
kubectl delete namespace <namespace-name>

4、pod管理

bash 复制代码
# 列出所有Pod(默认命名空间)
kubectl get pods

# 列出指定命名空间的Pod
kubectl get pods -n <namespace-name>

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

# 创建Pod(使用YAML文件)
kubectl apply -f <pod.yaml>

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

# 日志输出Pod
kubectl logs <pod-name>

# 进入Pod容器(类似于SSH)
kubectl exec -it <pod-name> -- /bin/bash

#查看pod的详细信息,包括失败原因
kubectl describe pod kube-flannel-ds-b2wpw -n kube-flannel

#删除失败pod
kubectl delete pod kube-flannel-ds-b2wpw -n kube-flannel

# Kubernetes 的网络插件通常以 DaemonSet 的形式运行在 kube-system 命名空间中。你可以列出所有 Pod 并筛选出网络插件相关的 Pod。
kubectl get pods -n kube-system

#查看这些 Pod 属于哪个 Deployment 或 ReplicaSet
kubectl get pods -n kube-system -o wide

#强制删除pod
kubectl delete pod coredns-66f779496c-wxf7c -n kube-system --force --grace-period=0

5、部署(Deployment)管理

bash 复制代码
# 列出所有部署
kubectl get deployments

# 创建部署(使用YAML文件)
kubectl apply -f <deployment.yaml>

# 更新部署
kubectl apply -f <deployment.yaml>

# 删除部署
kubectl delete deployment <deployment-name>

# 查看部署详细信息
kubectl describe deployment <deployment-name>

# 扩展/缩减部署的Pod数量
kubectl scale deployment <deployment-name> --replicas=<number>

6、服务(Service)管理

bash 复制代码
# 列出所有服务
kubectl get services

# 创建服务(使用YAML文件)
kubectl apply -f <service.yaml>

# 删除服务
kubectl delete service <service-name>

# 查看服务详细信息
kubectl describe service <service-name>

7、配置和秘密(ConfigMap & Secret)

bash 复制代码
# 列出所有ConfigMap
kubectl get configmaps

# 创建ConfigMap(使用YAML文件)
kubectl apply -f <configmap.yaml>

# 删除ConfigMap
kubectl delete configmap <configmap-name>

# 列出所有Secret
kubectl get secrets

# 创建Secret(使用YAML文件)
kubectl apply -f <secret.yaml>

# 删除Secret
kubectl delete secret <secret-name>

8、其他资源管理

bash 复制代码
# 列出所有ReplicaSet
kubectl get replicasets

# 列出所有DaemonSet
kubectl get daemonsets

# 列出所有StatefulSet
kubectl get statefulsets

# 列出所有CronJob
kubectl get cronjobs

# 创建资源(使用YAML文件)
kubectl apply -f <resource.yaml>

# 删除资源
kubectl delete -f <resource.yaml>

9、查看资源使用情况

bash 复制代码
# 查看当前命名空间中所有资源的使用情况
kubectl top pods

# 查看所有节点的资源使用情况
kubectl top nodes

10、管理YAML文件

bash 复制代码
# 通过YAML文件创建资源
kubectl create -f <resource.yaml>

# 通过YAML文件更新资源
kubectl apply -f <resource.yaml>

# 通过YAML文件删除资源
kubectl delete -f <resource.yaml>

这些命令是Kubernetes管理中最常用的一些基本操作,熟练掌握这些命令能够帮助你高效地管理Kubernetes集群和应用。

相关推荐
丈剑走天涯1 小时前
kubernetes Jenkins 二进制安装指南
java·kubernetes·jenkins
roman_日积跬步-终至千里1 小时前
【k8s 实战】使用 Helm 在 Minikube 部署 StarRocks(实战避坑指南)
云原生·容器·kubernetes
IT枫斗者2 小时前
CentOS 7 一键部署 K8s 1.23 + Rancher 2.7 完整指南
java·linux·spring boot·后端·kubernetes·centos·rancher
Q鑫2 小时前
K8s之pod解析与调度策略
docker·容器·kubernetes
数据智能老司机10 小时前
Kubernetes 上的生成式 AI——模型定制化
kubernetes·llm
数据智能老司机1 天前
Kubernetes 上的生成式 AI——模型数据
kubernetes·llm·agent
数据智能老司机1 天前
Kubernetes 上的生成式 AI——部署模型
kubernetes·aigc
Java陈序员3 天前
轻量强大!一款现代化的 Kubernetes 集群管理与监控工具!
云原生·容器·kubernetes
Johny_Zhao3 天前
OpenClaw中级到高级教程
linux·人工智能·信息安全·kubernetes·云计算·yum源·系统运维·openclaw
可观测性用观测云7 天前
云原生网关 Ingress-Nginx 链路追踪实战:OpenTelemetry 采集与观测云集成方案
nginx·kubernetes