Kubernetes K8S之kubectl命令详解及常用示例

Kubernetes kubectl命令详解与常用示例,基于k8s v1.17.4版本

kubectl常用示例

查看类命令

# 获取节点和服务版本信息  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 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或pod的资源使用情况  # 需要heapster 或metrics-server支持  kubectl top node  kubectl top pod    # 查看集群信息  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 <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  

进阶命令操作

# 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:动态伸缩  kubectl scale deploy myapp-deployment --replicas=5  # 动态伸缩  kubectl scale --replicas=8 -f myapp-deployment-v2.yaml  #动态伸缩【根据资源类型和名称伸缩,其他配置「如:镜像版本不同」不生效】  

上面滚动更新和动态伸缩涉及的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  
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等)。资源类型大小写敏感,可以指定单数、复数或缩写形式。例如,以下命令生成相同的输出:

kubectl get pod  -n kubernetes-dashboard  kubectl get pods -n kubernetes-dashboard  kubectl get po   -n kubernetes-dashboard  

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

# 示例:  [root@k8s-master ~]# kubectl get pods  No resources found in default namespace.  [root@k8s-master ~]# kubectl get pods --all-namespaces  # 或者 kubectl get pods --A  NAMESPACE              NAME                                         READY   STATUS    RESTARTS   AGE  kube-system            coredns-6955765f44-c9zfh                     1/1     Running   8          6d7h  kube-system            coredns-6955765f44-lrz5q                     1/1     Running   8          6d7h  kube-system            etcd-k8s-master                              1/1     Running   9          6d7h  kube-system            kube-apiserver-k8s-master                    1/1     Running   9          6d7h  kube-system            kube-controller-manager-k8s-master           1/1     Running   8          6d7h  kube-system            kube-flannel-ds-amd64-dngrk                  1/1     Running   13         6d7h  kube-system            kube-flannel-ds-amd64-h4sn6                  1/1     Running   13         6d6h  kube-system            kube-flannel-ds-amd64-m92wp                  1/1     Running   11         6d6h  kube-system            kube-proxy-28dwj                             1/1     Running   9          6d6h  kube-system            kube-proxy-c875m                             1/1     Running   8          6d7h  kube-system            kube-proxy-stg6w                             1/1     Running   10         6d6h  kube-system            kube-scheduler-k8s-master                    1/1     Running   9          6d7h  kubernetes-dashboard   dashboard-metrics-scraper-7b8b58dc8b-nr5fz   1/1     Running   7          6d1h  kubernetes-dashboard   kubernetes-dashboard-755dcb9575-9kg7p        1/1     Running   9          6d1h  [root@k8s-master ~]# kubectl get service --all-namespaces  # 或者 kubectl get service -A  NAMESPACE              NAME                        TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)                  AGE  default                kubernetes                  ClusterIP   10.96.0.1       <none>        443/TCP                  6d7h  kube-system            kube-dns                    ClusterIP   10.96.0.10      <none>        53/UDP,53/TCP,9153/TCP   6d7h  kubernetes-dashboard   dashboard-metrics-scraper   ClusterIP   10.104.12.221   <none>        8000/TCP                 6d1h  kubernetes-dashboard   kubernetes-dashboard        NodePort    10.110.157.29   <none>        443:30001/TCP            6d1h  

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    <none>        443/TCP   45h    NAME              STATUS   ROLES    AGE   VERSION  node/k8s-master   Ready    master   45h   v1.17.4  node/k8s-node01   Ready    <none>   45h   v1.17.4  node/k8s-node02   Ready    <none>   45h   v1.17.4  

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

# 使用YAML而不是JSON,因为YAML更容易使用,特别是对于配置文件。  kubectl get pod -f pod.yaml  
kubectl语法中的command操作

下表包括常见kubectl操作的简短描述和通用语法:

也可在命令行可通过kubectl -h 命令获取部分信息
或者通过以下地址查看更多详情:

https://kubernetes.io/docs/reference/generated/kubectl/kubectl-commands  https://kubernetes.io/docs/reference/kubectl/overview/#operations  

Kubernetes K8S之kubectl命令详解及常用示例

kubectl语法中的TYPE资源

下表包含常用的资源类型及其缩写别名的列表。

也可以在命令行通过kubectl api-resources得到。

Kubernetes K8S之kubectl命令详解及常用示例

kubectl 输出选项

格式化输出

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

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

语法

kubectl [command] [TYPE] [NAME] -o <output_format>  

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

Kubernetes K8S之kubectl命令详解及常用示例

示例

wide示例

[root@k8s-master ~]# kubectl get pod  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   1          28h  [root@k8s-master ~]#  [root@k8s-master ~]# kubectl get pod -o wide  NAME         READY   STATUS    RESTARTS   AGE   IP           NODE         NOMINATED NODE   READINESS GATES  nginx-demo   1/1     Running   1          28h   10.244.3.9   k8s-node01   <none>           <none>  

yaml示例

[root@k8s-master ~]# kubectl get pod  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   1          28h  [root@k8s-master ~]#  [root@k8s-master ~]# kubectl get pod -o yaml  apiVersion: v1  items:  - apiVersion: v1    kind: Pod    metadata:      annotations:  ………………  

json示例

[root@k8s-master ~]# kubectl get pod  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   1          28h  [root@k8s-master ~]#  [root@k8s-master ~]# kubectl get pod -o json  {      "apiVersion": "v1",      "items": [          {              "apiVersion": "v1",              "kind": "Pod",              "metadata": {                  "annotations": {  ………………  

name示例

[root@k8s-master ~]# kubectl get pod  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   1          28h  [root@k8s-master ~]#  [root@k8s-master ~]# kubectl get pod -o name  pod/nginx-demo  

custom-columns示例

[root@k8s-master ~]# kubectl get pod  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   1          29h  [root@k8s-master ~]#  [root@k8s-master ~]# kubectl get pods -o custom-columns=NAME:.metadata.name,UID:.metadata.uid,imageName:.spec.containers[0].image  NAME         UID                                    imageName  nginx-demo   08121fc6-969b-4b4e-9aa4-b990a5d02148   registry.cn-beijing.aliyuncs.com/google_registry/nginx:1.17  

说明:custom-columns=key:value;其中key表示列明;value表示要显示信息,这个value信息可以通过-o json或-o yaml获取。

custom-columns-file示例

[root@k8s-master test]# kubectl get pod  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   0          80s  [root@k8s-master test]#  # 要显示的列明和数据来源  [root@k8s-master test]# cat custom-col.conf  NAME          UID          imageName                containerPort  metadata.name metadata.uid spec.containers[0].image spec.containers[0].ports[0].containerPort  [root@k8s-master test]#  [root@k8s-master test]# kubectl get pod -o custom-columns-file=custom-col.conf  NAME         UID                                    imageName                                                     containerPort  nginx-demo   769dc3f4-2ffc-407c-a351-56b74ddaba4c   registry.cn-beijing.aliyuncs.com/google_registry/nginx:1.17   80  

jsonpath示例

[root@k8s-master test]# kubectl get pods  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   0          13m  [root@k8s-master test]#  [root@k8s-master test]# kubectl get pods -o jsonpath='{.items[0].metadata.name},{.items[0].spec.containers[0].image}'  nginx-demo,registry.cn-beijing.aliyuncs.com/google_registry/nginx:1.17  

jsonpath-file示例

[root@k8s-master test]# kubectl get pod  NAME         READY   STATUS    RESTARTS   AGE  nginx-demo   1/1     Running   0          16m  [root@k8s-master test]#  # 要显示的数据来源  [root@k8s-master test]# cat custom-json.conf  {.items[0].metadata.name},{.items[0].spec.containers[0].image},{.items[0].spec.containers[0].ports[0].containerPort}  [root@k8s-master test]#  [root@k8s-master test]# kubectl get pod -o jsonpath-file=custom-json.conf  nginx-demo,registry.cn-beijing.aliyuncs.com/google_registry/nginx:1.17,80  

完毕!

 

原文出处:zhangblog -> http://www.zhangblog.com/2020/08/09/kubernetes05/

本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如果侵犯你的利益,请发送邮箱到 [email protected],我们会很快的为您处理。
超哥软件库 » Kubernetes K8S之kubectl命令详解及常用示例