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集群和应用。

相关推荐
lijun_xiao20092 小时前
DevOps(devops/k8s/docker/Linux)学习笔记-4
docker·kubernetes·devops
坚持的小马3 小时前
k8s中执行脚本如果提示etcd找不到,可以做如下的操作
容器·kubernetes·etcd
easy_coder3 小时前
从HDFS NN报错看Flink+K8s+HDFS:基础、架构与问题关联
hdfs·flink·kubernetes
回忆是昨天里的海4 小时前
k8s-部署springboot容器化应用
java·容器·kubernetes
hkNaruto5 小时前
【k8s】Kubernetes 资源限制设置规范手册 MB与MiB的概念混淆问题
云原生·容器·kubernetes
Xander W7 小时前
基于K8s集群的PyTorch DDP 框架分布式训练测试(开发机版)
人工智能·pytorch·分布式·python·深度学习·kubernetes
pp-周子晗(努力赶上课程进度版)8 小时前
Docker、Kubernetes与AWS中控机是什么?
docker·容器·kubernetes·aws
不爱笑的良田13 小时前
从零开始的云原生之旅(十一):压测实战:验证弹性伸缩效果
云原生·容器·kubernetes·go·压力测试·k6
一枚正在学习的小白1 天前
k8s的包管理工具helm3--流程控制语句和变量(3)
linux·运维·服务器·云原生·kubernetes