1、查看类命令 # 获取节点和服务版本信息 kubectl get nodes # 获取节点和服务版本信息,并查看附加信息 kubectl get nodes -o wide # 获取pod信息,默认是default名称空间 kubectl get pod # 获取pod信息,默认是default名称空间,并查看附加信息如:pod的IP及在哪个节点运行 kubectl get pod -o wide # 获取指定名称空间kube-system的pod kubectl get pod -n kube-system # 获取指定名称空间kube-system中的指定pod kubectl get pod -n kube-system podName # 获取所有名称空间的pod kubectl get pod -A # 查看pod的详细信息,以yaml格式或json格式显示 kubectl get pods -o yaml kubectl get pods -o json # 查看pod的标签信息 kubectl get pod -A --show-labels # 根据Selector(label query)来查询pod kubectl get pod -A --selector="k8s-app=kube-dns" # 查看运行pod的环境变量 kubectl exec podName env # 查看指定pod的日志 kubectl logs -f --tail 500 -n kube-system kube-apiserver-k8s-master # 查看所有名称空间的service信息 kubectl get svc -A # 查看指定名称空间的service信息 kubectl get svc -n kube-system # 查看componentstatuses信息 kubectl get cs # 查看所有configmaps信息 kubectl get cm -A # 查看所有serviceaccounts信息 kubectl get sa -A # 查看所有daemonsets信息 kubectl get ds -A # 查看所有deployments信息 kubectl get deploy -A # 查看所有replicasets信息 kubectl get rs -A # 查看所有statefulsets信息 kubectl get sts -A # 查看所有jobs信息 kubectl get jobs -A # 查看所有ingresses信息 kubectl get ing -A # 查看有哪些名称空间 kubectl get ns # 查看pod的描述信息 kubectl describe pod podName kubectl describe pod -n kube-system kube-apiserver-k8s-master # 查看指定名称空间中指定deploy的描述信息 kubectl describe deploy -n kube-system coredns #查看node节点的描述信息 kubectl describe node xxx # 查看node或pod的资源实时使用情况 # 需要heapster 或metrics-server支持 kubectl top node kubectl top pod #同时查看多个pod资源使用情况 kubectl top pod |grep -E "aa|bb|cc" #同时查看同一台node节点上所有pod的资源使用情况 kubectl top pod |grep -E `kubectl get pod -o wide |grep xxx |awk '{print $1}'|xargs echo |sed 's/ /|/g'` # 查看集群信息 kubectl cluster-info 或 kubectl cluster-info dump # 查看各组件信息172.16.1.110为master机器 kubectl -s https://172.16.1.110:6443 get componentstatuses 2、操作类命令 # 创建资源 kubectl create -f xxx.yaml # 应用资源 kubectl apply -f xxx.yaml # 应用资源,该目录下的所有 .yaml, .yml, 或 .json 文件都会被使用 kubectl apply -f <directory> # 创建test名称空间 kubectl create namespace test # 删除资源 kubectl delete -f xxx.yaml kubectl delete -f <directory> # 删除指定的pod kubectl delete pod podName # 删除指定名称空间的指定pod kubectl delete pod -n test podName # 删除其他资源 kubectl delete svc svcName kubectl delete deploy deployName kubectl delete ns nsName # 强制删除 kubectl delete pod podName -n nsName --grace-period=0 --force kubectl delete pod podName -n nsName --grace-period=1 kubectl delete pod podName -n nsName --now # 编辑资源 kubectl edit pod podName #编辑修改service kubectl edit svc servicename kubectl edit svc nginx ..... spec: ..... # 默认创建的时候为ClusterIP类型,可这样动态修改,亦或创建时通过"type=NodePort"指定(区分大小写.) type: NodePort ..... kubectl get svc 3、进阶命令操作 # kubectl exec:进入pod启动的容器 kubectl exec -it podName -n nsName /bin/sh #进入容器 kubectl exec -it podName -n nsName /bin/bash #进入容器 # kubectl label:添加label值 kubectl label nodes k8s-node01 zone=north #为指定节点添加标签 kubectl label nodes k8s-node01 zone- #为指定节点删除标签 kubectl label pod podName -n nsName role-name=test #为指定pod添加标签 kubectl label pod podName -n nsName role-name=dev --overwrite #修改lable标签值 kubectl label pod podName -n nsName role-name- #删除lable标签 # kubectl滚动升级; 通过 kubectl apply -f myapp-deployment-v1.yaml 启动deploy kubectl apply -f myapp-deployment-v2.yaml #通过配置文件滚动升级 kubectl set image deploy/myapp-deployment myapp="registry.cn-beijing.aliyuncs.com/google_registry/myapp:v3" #通过命令滚动升级 kubectl rollout undo deploy/myapp-deployment 或者 kubectl rollout undo deploy myapp-deployment #pod回滚到前一个版本 kubectl rollout undo deploy/myapp-deployment --to-revision=2 #回滚到指定历史版本 # kubectl scale:动态伸缩,将现有pod数量增加/减少到指定数量 kubectl scale deploy myapp-deployment --replicas=5 # 动态伸缩 kubectl scale --replicas=8 -f myapp-deployment-v2.yaml #动态伸缩根据资源类型和名称伸缩,其他配置「如:镜像版本不同」不生效 4、kubectl replace 重启pod的四种方法 一、有yaml文件的情况下 kubectl replace --force -f xxx.yaml ##replace 结合--force进行重启 二、没有yaml文件的情况下 kubectl get deploy xx -o yaml |kubectl replace --force -f - #通过-o yaml获取yaml文件,再replace重启 三、删除deploy/sts, 后重建 Kubectl get deploy xx -o yaml >/yy/xx.yaml kubectl delete deploy xx && kubectl apply -f /yy/xx.yaml 四、删除pod后,deploy/sts..等自动调度重启pod kubectl delete pod xxx
标签:kubectl,查看,Kubernetes,get,deploy,yaml,指令,pod,K8s From: https://www.cnblogs.com/gkhost/p/18180998