目录

1、查看类命令

2、操作类命令

3、进阶命令操作

4、kubectl replace 重启pod的四种方法

5、kubectl语法

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 # 创建test名称空间 kubectl create namespace test

# 删除资源 kubectl delete -f xxx.yaml kubectl delete -f # 删除指定的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

## 修改node节点标签 kubectl label nodes nodeName node-role.kubernetes.io/node= # 删除node节点标签 kubectl label nodes nodeName node-role.kubernetes.io/node-

# 编辑资源 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​​

​​##例如--replicas=3,如果删除一个pod,则会自动重新拉起一个pod。​​

上面滚动更新和动态伸缩涉及的deploy的yaml文件

[root@k8s-master deploy]# cat myapp-deployment-v1.yaml

apiVersion: apps/v1

kind: Deployment

metadata:

name: myapp-deployment

labels:

app: myapp

spec:

replicas: 10

# 重点关注该字段

selector:

matchLabels:

app: myapp

template:

metadata:

labels:

app: myapp

spec:

containers:

- name: myapp

image: registry.cn-beijing.aliyuncs.com/google_registry/myapp:v1

ports:

- containerPort: 80

[root@k8s-master deploy]#

[root@k8s-master deploy]# cat myapp-deployment-v2.yaml

apiVersion: apps/v1

kind: Deployment

metadata:

name: myapp-deployment

labels:

app: myapp

spec:

replicas: 10

# 重点关注该字段

selector:

matchLabels:

app: myapp

template:

metadata:

labels:

app: myapp

spec:

containers:

- name: myapp

image: registry.cn-beijing.aliyuncs.com/google_registry/myapp:v2

ports:

- containerPort: 80

5、kubectl语法

kubectl [command] [TYPE] [NAME] [flags]

官网地址:https://kubernetes.io/docs/reference/kubectl/overview/ kubectl flags:https://kubernetes.io/docs/reference/kubectl/kubectl/

1、command:指定在一个或多个资源上要执行的操作。例如:create、get、describe、delete、apply等

2、TYPE:指定资源类型(如:pod、node、services、deployments等)。资源类型大小写敏感,可以指定单数、复数或缩写形式。

3、NAME:指定资源的名称。名称大小写敏感。如果省略名称空间,则显示默认名称空间资源的详细信息或者提示:No resources found in default namespace.。

4、flags:指定可选的标记。例如,可以使用 -s 或 --server标识来指定Kubernetes API服务器的地址和端口;-n指定名称空间;等等。

注意:你从命令行指定的flags将覆盖默认值和任何相应的环境变量。优先级最高。

5、在多个资源上执行操作时,可以通过类型 [TYPE] 和名称 [NAME] 指定每个资源,也可以指定一个或多个文件。

按类型和名称指定资源:

# 查看一个资源类型中的多个资源

[root@k8s-master ~]# kubectl get pod -n kube-system coredns-6955765f44-c9zfh kube-proxy-28dwj

NAME READY STATUS RESTARTS AGE

coredns-6955765f44-c9zfh 1/1 Running 8 6d7h

kube-proxy-28dwj 1/1 Running 9 6d6h

[root@k8s-master ~]#

# 查看多个资源类型

[root@k8s-master ~]# kubectl get svc,node

NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE

service/kubernetes ClusterIP 10.96.0.1 443/TCP 45h

NAME STATUS ROLES AGE VERSION

node/k8s-master Ready master 45h v1.17.4

node/k8s-node01 Ready 45h v1.17.4

node/k8s-node02 Ready 45h v1.17.4

使用一个或多个文件指定资源:-f file1 -f file2 -f file<#> 

# 使用YAML而不是JSON,因为YAML更容易使用,特别是对于配置文件。

kubectl get pod -f pod.yaml

kubectl语法中的command操作 可在命令行可通过kubectl -h 命令获取部分信息 或者通过以下地址查看更多详情: https://kubernetes.io/docs/reference/generated/kubectl/kubectl-commands  https://kubernetes.io/docs/reference/kubectl/overview/#operations

kubectl语法中的TYPE资源 可以在命令行通过kubectl api-resources得到。

kubectl 输出选项 格式化输出 所有kubectl命令的默认输出格式是人类可读的纯文本格式。

要将详细信息以特定的格式输出到终端窗口,可以将 -o 或 --output标识添加到受支持的kubectl命令中。

语法: kubectl [command] [TYPE] [NAME] -o  

根据kubectl操作,支持以下输出格式:

Output format    Description -o custom-columns= 使用逗号分隔的自定义列列表打印表-o custom-columns-file=使用文件中的自定义列模板打印表-o json输出一个JSON格式的API对象-o jsonpath=打印jsonpath表达式中定义的字段-o jsonpath-file=通过文件打印jsonpath表达式定义的字段 -o name 只打印资源名,不打印其他任何内容-o wide以纯文本格式输出,包含附加信息。对于pods,包含节点名-o yaml 输出一个YAML格式的API对  

相关阅读

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: