k8s常用命令集合,新人的福音

admin 2025-02-04 15:58:31 31

Kubernetes(通常简称为 k8s)是一个开源的容器编排平台,用于自动化部署、扩展以及管理容器化应用程序方面发挥着极为关键的作用。以下是一些常用的 Kubernetes 命令:

一、集群信息查询

  • kubectl version:查看集群的版本信息。
  • kubectl api-versions:输出一系列的 API 组及其对应的版本号。
  • kubectl api-resources:输出服务端 API 支持的资源类型。
  • kubectl cluster-info:查看集群信息。
  • kubectl cluster-info dump:查看集群更详细的信息。

二、资源详细信息查看

  • kubectl describe <资源类型,如:deployments> <资源名称>:查看特定资源的详细信息。
  • kubectl -n <命名空间> describe pod <pod-name>:查看指定命名空间下指定 pod 的详细信息,加-o wide参数显示详细信息。
  • kubectl describe nodes:显示集群节点资源:CPU、GPU、内存的使用情况以及标签;nodes 后可加具体节点名。

三、资源创建

  • kubectl apply -f <文件名>:更新资源&创建资源(推荐)。
  • kubectl create -f <文件名>:创建资源。
  • kubectl create -f.:创建当前目录下的所有 yaml 资源。
  • kubectl create -f./app1.yaml -f./app2.yaml:批量创建资源。

四、资源删除

  • kubectl delete pod <pod-name>:删除指定 pod。
  • kubectl delete service <service-name>:删除指定 service。
  • kubectl delete <资源类型> <资源名称>:删除指定资源。
  • kubectl delete -f./pod.json:删除 pod.json 文件中定义的类型和名称的 pod。
  • kubectl delete pods --all -n <命名空间>:删除指定命令空间下所有的 pod;pods 改为 services 即为删除所有的 services。
  • kubectl delete pod <pod-name> -n <命令空间> --force --grace-period=0:强制删除 pod。
  • kubectl delete pods <pod-name> -n <命名空间>:静态 POD 直接删除,非静态 POD 重启。
  • kubectl delete pods,services -l name=<标签名>:删除指定标签 pod 和 serivce;加--include-uninitialized(含尚未初始化)。

五、资源扩缩容

  • kubectl scale <资源类型,如 rc> <资源名称,如 rc-nginx-2> --replicas=5:扩展副本数到 5。
  • kubectl scale rc rc-nginx-2 —replicas=3:副本数缩减到 3。
  • kubectl autoscale deployment my-app --min=3 --max=10:自动扩缩容 my-app 的部署,指定副本范围在 3~10。
  • --cpu-percent=80:上条命令结尾如果加这段的话,代表当 CPU 使用率达到 80% 时触发以上自动扩缩容操作。

六、资源使用情况查询

  • kubectl top node k8s-node:显示节点(k8s-node)资源的使用情况。
  • kubectl top node:显示集群所有节点的资源的使用情况。
  • kubectl top pod -n logging:显示指定命名空间(如,logging)的 pod 的资源的使用情况。

七、资源注解更新

  • kubectl annotate pods <pod-name> description='my frontend':更新 pod,设置其注解description的值为my frontend

八、容器操作

  • kubectl -n <命名空间> exec -it <Pod 名称> -- bash:登录容器的命令。
  • kubectl -n <命名空间> cp /opt/sql <Pod 名称>:/tmp/:复制本机/opt/sql 路径下的文件到 pod 的 /tmp/路径下。
  • kubectl -n <命名空间> cp <Pod 名称>:/tmp/app_bak ./mysql_bak/:复制 Pod 内app_bak路径所有文件到本地 mysql_bak 路径。

九、回滚和历史查看

  • cat pod.json | kubectl apply -f -:将控制台输入的 JSON 配置应用到 Pod。
  • kubectl rollout history deployment nginx-deployment:查看修订版本的历史记录。
  • kubectl rollout undo deployment nginx-deployment --to-revision=1:如果不加 –to-revision=版本号,会回退到上一个版本。

十、资源配额与限制查看

  • kubectl describe quota:查看集群的资源配额。
  • kubectl describe limitrange:查看集群的资源限制。

十一、日志查看

  • kubectl logs -f <Pod 名称> -n <命名空间>:查看指定 Pod 的日志。
  • kubectl logs --tail=10 <Pod 名称>:查看指定 pod 的最后 10 行日志。
  • kubectl logs <Pod 名称> -n <命名空间> | grep 关键字:根据关键字查看日志。

十二、节点与标签操作

  • kubectl get nodes --show-labels:查看所有节点和 label。
  • kubectl label nodes <节点名> <标签键>=<标签名>:给节点增加标签。
  • kubectl label nodes <节点名> <标签键>-:给节点去掉(删除)标签。
  • kubectl taint nodes <节点名> <标签键>=true:NoSchedule:给节点增加污点。
  • kubectl taint nodes <节点名> <标签键>:NoSchedule-:给节点去掉(删除)污点。
  • kubectl taint nodes --all <标签键>:NoSchedule-:删除所有节点的指导标签。

十三、服务编辑

  • kubectl edit svc/docker-registry:编辑名为 docker-registry 的 service。

十四、资源列表查看

  • kubectl get pods -A:查看所有的 pod。
  • kubectl get pods -n <命名空间>:查看特定命名空间下的 Pod 列表。
  • kubectl get po -A|grep -Ev '1/1|2/2|3/3|4/4|Com':查看异常 pod 的列表。
  • kubectl get pods -o wide | grep <需查询 pod 的关键字>:查询包含特定关键字的 Pod,并且输出详细信息。
  • kubectl get namespaces:查看命名空间列表。
  • kubectl get nodes:查看节点列表,可以加上 --show-labels查看 label,可以加上 -o wide 查看 IP。
  • kubectl get services:查看集群中服务的状态。
  • kubectl get statefulset:查看 statefulset 列表,中间件与底座大量使用该类型控制器。
  • kubectl get daemonset:查看 daemonset 列表,基础组件大量使用该类型控制器。
  • kubectl get deployments:查看 deployment 列表,大部分组件使用该类型控制器。
  • kubectl get svc:查看服务列表,可指定参数 -A 参看所有命名空间中的服务。
  • kubectl get ingress -A:查看域名列表,可指定参数 -A 参看所有命名空间中的对外域名列表。
  • kubectl get crd -A:查看自定义资源列表。
  • kubectl get networkpolicies:查看集群的网络策略。
  • kubectl get storageclass:查看集群的存储类。

十五、资源格式信息获取

  • kubectl get <资源类型,如 deployment> <资源名称,如 my-deployment> -o yaml:获取指定 namespace 的 yaml 格式格式信息。
  • kubectl get <资源类型,如 deployment> <资源名称,如 my-deployment> -o json:获取指定 namespace 的 json 格式信息。

十六、节点调度管理

  • kubectl cordon k8s-node:标记 k8s-node 节点不可调度。
  • kubectl uncordon k8s-node:标记 k8s-node 节点可调度。
  • kubectl drain k8s-node:排除 k8s-node 节点,准备进行维护。
可爱猫?Telegram电报群 https://t.me/ikeaimao

社区声明 1、本站提供的一切软件、教程和内容信息仅限用于学习和研究目的
2、本站资源为用户分享,如有侵权请邮件与我们联系处理敬请谅解!
3、本站信息来自网络,版权争议与本站无关。您必须在下载后的24小时之内,从您的电脑或手机中彻底删除上述内容
最新回复 (0)

您可以在 登录 or 注册 后,对此帖发表评论!

返回