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 小时前
K8S资源限制之LimitRange
云原生·容器·kubernetes·k8s资源限制
登云时刻1 小时前
Kubernetes集群外连接redis集群和使用redis-shake工具迁移数据(二)
redis·容器·kubernetes
wuxingge10 小时前
k8s1.30.0高可用集群部署
云原生·容器·kubernetes
志凌海纳SmartX11 小时前
趋势洞察|AI 能否带动裸金属 K8s 强势崛起?
云原生·容器·kubernetes
锅总11 小时前
nacos与k8s service健康检查详解
云原生·容器·kubernetes
BUG弄潮儿11 小时前
k8s 集群安装
云原生·容器·kubernetes
颜淡慕潇13 小时前
【K8S系列】kubectl describe pod显示ImagePullBackOff,如何进一步排查?
后端·云原生·容器·kubernetes
Linux运维日记13 小时前
k8s1.31版本最新版本集群使用容器镜像仓库Harbor
linux·docker·云原生·容器·kubernetes
AI_小站15 小时前
RAG 示例:使用 langchain、Redis、llama.cpp 构建一个 kubernetes 知识库问答
人工智能·程序人生·langchain·kubernetes·llama·知识库·rag
长囧鹿18 小时前
云原生之k8s服务管理
云原生·容器·kubernetes