1.命令 ```

获取节点和服务版本信息

kubectl get nodes

获取节点和服务版本信息,并查看附加信息

kubectl get nodes -o wide

获取pod信息,默认是default名称空间

kubectl get pod

获取pod信息,默认是default名称空间,并查看附加信息【如:pod的IP及在哪个节点运行】

kubectl get pod -o wide

获取指定名称空间的pod

kubectl get pod -n

获取指定名称空间中的指定pod

kubectl get pod podName -n

获取所有名称空间的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

查看所有名称空间的service信息

kubectl get svc -A

查看指定名称空间的service信息

kubectl get svc -n

查看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 kubectl describe pod -n

查看node或pod的资源使用情况

需要heapster 或metrics-server支持

kubectl top node kubectl top pod

查看指定命令空间下指定pod下的容器信息

kubectl describe pod -n |grep container

查看集群信息

kubectl cluster-info 或 kubectl cluster-info dump

查看各组件信息【172.16.1.110为master机器】

kubectl -s https://172.16.1.110:6443 get componentstatuses

创建资源

kubectl create -f xxx.yaml

应用资源

kubectl apply -f xxx.yaml

应用资源,该目录下的所有 .yaml, .yml, 或 .json 文件都会被使用

kubectl apply -f

创建test名称空间

kubectl create namespace test

删除资源

kubectl delete -f xxx.yaml kubectl delete -f

删除指定的pod

kubectl delete pod podName

删除指定名称空间的指定pod

kubectl delete pod -n 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 -n

kubectl exec:进入pod启动的容器

kubectl exec -it podName -n /bin/sh #进入容器 kubectl exec -it podName -n /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:动态伸缩

kubectl scale deploy myapp-deployment —replicas=5

动态伸缩【根据资源类型和名称伸缩,其他配置「如:镜像版本不同」不生效】

kubectl scale —replicas=8 -f myapp-deployment-v2.yaml

  1. 2.操作

加 -o yml —dry-run 生成yml文件不在集群中运行

kubectl create deployment web —image=nginx -o yml —dry-run

从已存在的应用获取yml文件

kubectl get deploy nginx -o=yml —export>1.yml 暴漏端口 kubectl expose deployment my-dep —port=8000 —target-port=80 —type=NodePort ``` https://blog.csdn.net/qq_38304320/article/details/121051583