首页 > 其他分享 >Kubernetes 备忘录

Kubernetes 备忘录

时间:2024-11-06 21:58:56浏览次数:3  
标签:kubectl name Kubernetes get -- 备忘录 yaml pod

Kubernetes 备忘录

Kubernetes 备忘清单

查看资源信息


节点

资源名称: nodes, 缩写: no

$ kubectl get no          # 显示所有节点信息
# 显示所有节点的更多信息
$ kubectl get no -o wide  
$ kubectl describe no     # 显示节点详情
# 以yaml格式,显示节点详情
$ kubectl get no -o yaml  
# 筛选指定标签的节点
$ kubectl get node --selector=[label_name] 
# 输出 jsonpath 表达式定义的字段信息
$ kubectl get nodes -o jsonpath='{.items[*].status.addresses[?(@.type=="ExternalIP")].address}'
# 显示节点(CPU/内存/存储)使用情况
$ kubectl top node [node_name]

容器组

资源名称: pods, 缩写: po

$ kubectl get po              # 显示所有容器组信息
$ kubectl get po -o wide
$ kubectl describe po
$ kubectl get po --show-labels # 查看容器组的labels
$ kubectl get po -l app=nginx
$ kubectl get po -o yaml
$ kubectl get pod [pod_name] -o yaml --export
$ kubectl get pod [pod_name] -o yaml --export > nameoffile.yaml 
# 以yaml格式导出容器组信息到yaml文件
$ kubectl get pods --field-selector status.phase=Running     
# 使用字段选择器筛选出容器组信息

命名空间

资源名称: namespaces, 缩写: ns

$ kubectl get ns
$ kubectl get ns -o yaml
$ kubectl describe ns

无状态

资源名称: deployments, 缩写: deploy

$ kubectl get deploy
$ kubectl describe deploy
$ kubectl get deploy -o wide 
$ kubectl get deploy -o yaml

服务

资源名称: services, 缩写: svc

$ kubectl get svc
$ kubectl describe svc
$ kubectl get svc -o wide 
$ kubectl get svc -o yaml
$ kubectl get svc --show-labels

守护进程集

资源名称: daemonsets, 缩写: ds

$ kubectl get ds
$ kubectl describe ds --all-namespaces
$ kubectl describe ds [daemonset_name] -n [namespace_name]
$ kubectl get ds [ds_name] -n [ns_name] -o yaml

事件

资源名称: events, 缩写: ev

$ kubectl get events 
$ kubectl get events -n kube-system
$ kubectl get events -w

服务帐户

资源名称: serviceaccounts, 缩写: sa

$ kubectl get sa
$ kubectl get sa -o yaml
$ kubectl get serviceaccounts default -o yaml >./sa.yaml
$ kubectl replace serviceaccount default -f ./sa.yaml

日志

$ kubectl logs [pod_name]
$ kubectl logs --since=1h [pod_name]
$ kubectl logs --tail=20 [pod_name]
$ kubectl logs \
      -f -c [container_name] [pod_name]
$ kubectl logs [pod_name] > pod.log

副本集

资源名称: replicasets, 缩写: rs

$ kubectl get rs
$ kubectl describe rs
$ kubectl get rs -o wide 
$ kubectl get rs -o yaml

角色

$ kubectl get roles --all-namespaces

$ kubectl get roles \
      --all-namespaces -o yaml

保密字典

$ kubectl get secrets
$ kubectl get secrets --all-namespaces 
$ kubectl get secrets -o yaml

配置项

资源名称: configmaps, 缩写: cm

$ kubectl get cm
$ kubectl get cm --all-namespaces
$ kubectl get cm --all-namespaces -o yaml

路由

资源名称: ingresses, 缩写: ing

$ kubectl get ing
$ kubectl get ing --all-namespaces

持久卷

资源名称: persistentvolumes, 缩写: pv

$ kubectl get pv 
$ kubectl describe pv

持久卷声明

资源名称: persistentvolumeclaims, 缩写: pvc

$ kubectl get pvc
$ kubectl describe pvc

存储类

资源名称: storageclasses, 缩写: sc

$ kubectl get sc
$ kubectl get sc -o yaml

多个资源

$ kubectl get svc, po
$ kubectl get deploy, no
$ kubectl get all
$ kubectl get all --all-namespaces

变更资源属性


污点

$ kubectl taint [node_name] [taint_name]

标签

$ kubectl label nodes <node-name> <label-key>=<label-value>  #增加
$ kubectl label nodes <node-name> <label-key>- #删除
$ kubectl label nodes <node-name> <label-key>=<label-value> --overwrite #修改

维护/可调度

$ kubectl cordon [node_name]   # 节点维护
$ kubectl uncordon [node_name] # 节点可调度

清空节点

$ kubectl drain [node_name]    # 清空节点

节点/容器组

$ kubectl delete node [node_name] 
$ kubectl delete pod [pod_name]
$ kubectl edit node [node_name]
$ kubectl edit pod [pod_name]

无状态/命名空间

$ kubectl edit deploy [deploy_name]
$ kubectl delete deploy [deploy_name]
$ kubectl expose deploy [deploy_name] --port=80 --type=NodePort
$ kubectl scale deploy [deploy_name] --replicas=5
$ kubectl delete ns
$ kubectl edit ns [ns_name]

服务

$ kubectl edit svc [svc_name]
$ kubectl delete svc [svc_name]

守护进程集

$ kubectl edit ds [ds_name] -n kube-system 
$ kubectl delete ds [ds_name]

服务账号

$ kubectl edit sa [sa_name]
$ kubectl delete sa [sa_name]

注释

$ kubectl annotatepo [pod_name] [annotation]
$ kubectl annotateno [node_name]

添加资源


创建容器组

$ kubectl create -f [name_of_file] 
$ kubectl apply -f [name_of_file]
$ kubectl run [pod_name] --image=nginx --restart=Never
$ kubectl run [pod_name] --generator=run-pod/v1 --image=nginx
$ kubectl run [pod_name] --image=nginx --restart=Never

创建服务

$ kubectl create svc nodeport [svc_name] \
      --tcp=8080:80

创建无状态应用

$ kubectl create -f [name_of_file] 
$ kubectl apply -f [name_of_file]
$ kubectl create deploy [deploy_name] \
      --image=nginx

输出YAML文件

$ kubectl create deploy [deploy_name] --image=nginx --dry-run -o yaml > deploy.yaml
$ kubectl get po [pod_name] -o yaml --export > pod.yaml
$ kubectl run nginx --image=nginx:alpine --dry-run -o -yaml > deploy.yaml

容器交互

$ kubectl run [pod_name] \
        --image=busybox --rm -it \
        --restart=Never -- sh

获取帮助

$ kubectl -h
$ kubectl create -h
$ kubectl run -h
$ kubectl explain deploy.spec

请求


API调用

$ kubectl get --raw /apis/metrics.k8s.io/

集群信息

$ kubectl config
$ kubectl cluster-info
$ kubectl get componentstatus

另见


标签:kubectl,name,Kubernetes,get,--,备忘录,yaml,pod
From: https://www.cnblogs.com/qinzhi1209/p/18531145/kubernetes-memo-z1pi2sl

相关文章

  • Kubernetes 维护指导
    Kubernetes维护指导Kubernetes维护指导如果你在阅读本文时发现了任何错误,请在Github上提交ISSUE(或PR),我将由衷地表示感谢。为了方便阅读,请点击网页右侧的按钮在右侧展开目录以了解全文大纲。1.节点管理在此章节中,本文将以Kubernetes集群中的节点管理为主题进行深入探讨......
  • 00-Ansible备忘录
    00-Ansible备忘录Ansible备忘清单此快速参考备忘单提供了使用Ansible的各种方法。入门安装安装命令环境brewinstallansiblemacosyuminstall-yansiblecentospipinstallansiblepythonAnsible官方文档配置位置文件路径说明/etc......
  • 5个维度对Kubernetes集群优化
    5个维度对Kubernetes集群优化一、节点配额和内核参数调整对于公有云上的Kubernetes集群,规模大了之后很容器碰到配额问题,需要提前在云平台上增大配额。这些需要增大的配额包括:虚拟机个数vCPU个数内网IP地址个数公网IP地址个数安全组条数路由表条数持久化存储大小......
  • Kubernetes架构及核心组件
    一、基本架构Kubernetes集群可以被看作是一个工厂,而各个组件则是这个工厂里的不同部门:KubernetesAPI服务器:就像是这个工厂的总经理,负责接收所有的请求并将它们分配给相应的部门进行处理。etcd:就像是这个工厂的记事本,负责记录所有的配置信息和状态信息,以便其他组件可......
  • 5分钟上手 Kubernetes:精简实用的 Kubectl 命令速查宝典!
    对于刚开始学习Kubernetes的人来说,理解和掌握kubectl命令是入门的第一步。kubectl是Kubernetes的命令行工具,用于管理Kubernetes集群中的资源。在这篇文章中,我们将总结一些最常用的kubectl命令,通过简明的介绍和示例,让你在5分钟内快速上手Kubernetes,优雅地开始使用K8......
  • kubernetes删除ns异常状态为:Terminating
    用kubernetes-API删除1、首先,获取要删除NameSpace的 JSON 文件:替换其中的<terminating-namespace>为实际namespacekubectlgetnamespace<terminating-namespace>-ojson>tmp.json[root@master01~]#kubectlgetnamespacekuboard-ojson>tmp.json2、编辑......
  • Kubernetes-K8S的安装
    前言:望大家可以跟着我的走,我将自己踩的坑都会一一说出来,尽量为大家踩出一条没有荆棘的路,有问题大家可以留言和私信我会一一解答,我不是大神就是一个学习小伙汁,那么接下来让我们开始安装步骤建议使用阿里云的服务器首先开通三个2核2G的ECS云服务器(按量付费)安装Kuber......
  • 【K8s】专题十五(1):Kubernetes 网络之概念总览
    本文内容均来自个人笔记并重新梳理,如有错误欢迎指正!如果对您有帮助,烦请点赞、关注、转发、订阅专栏!专栏订阅入口| 精选文章 | Kubernetes |Docker|Linux |羊毛资源 | 工具推荐 |往期精彩文章【Docker】(全网首发)KylinV10下MySQL容器内存占用异常的解决......
  • 使用Velero备份、恢复、迁移Kubernetes集群
    使用Velero备份、恢复、迁移Kubernetes集群VeleroVelero属于VMWare开源的Kubernetes集群备份、恢复、迁移工具.可以提供Kubernetes备份功能更,在Kubernetes集群出现问题之后,能够快速的恢复.并且也提供了集群迁移功能,可以将Kubernetes资源迁移到其他集群.Velero将备份的信息在......
  • Kubernetes的YAML文件怎么写
    在编写Kubernetes的YAML文件时,关键是要理解其作用、结构和语法。KubernetesYAML文件主要用于描述资源的期望状态、包含必要的元数据、以及指定资源的配置信息。其中,遵循正确的缩进风格是编写有效YAML文件的必要条件,因为YAML中的层次结构是通过缩进表示的,一个常见的错误就是层次关......