• K8S命令行工具——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<br>
    # 获取所有名称空间的pod
    kubectl get pod -A
    # 查看pod的详细信息,以yaml格式或json格式显示
    kubectl get pods -o yaml
    kubectl get pods -o json
     
    # 显示 Node 的详细信息
    kubectl describe node 192.168.0.212
    # 查看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  #动态伸缩【根据资源类型和名称伸缩,其他配置「如:镜像版本不同」不生效】

     日志查看:

    # Usage:
      kubectl logs [-f] [-p] (POD | TYPE/NAME) [-c CONTAINER] [options]
    # Examples: 
    kubectl logs my-pod                              
    # 输出一个单容器pod my-pod的日志到标准输出
    kubectl logs nginx-78f5d695bd-czm8z -c nginx     
    # 输出多容器pod中的某个nginx容器的日志
    kubectl logs -l app=nginx                        
    # 输出所有包含app-nginx标签的pod日志
    kubectl logs -f my-pod                           
    # 加上-f参数跟踪日志,类似tail -f
    kubectl logs my-pod  -p                          
    # 输出该pod的上一个退出的容器实例日志。在pod容器异常退出时很有用
    kubectl logs my-pod  --since-time=2018-11-01T15:00:00Z
    # 指定时间戳输出日志            
    kubectl logs my-pod  --since=1h 
    # 指定时间段输出日志,单位s/m/h

    文件传输

    # Usage:
    kubectl cp <file-spec-src> <file-spec-dest> [options]
    # Examples:  
    kubectl cp /tmp/foo_dir <some-pod>:/tmp/bar_dir                 # 拷贝宿主机本地文件夹到pod
    kubectl cp <some-namespace>/<some-pod>:/tmp/foo /tmp/bar        # 指定namespace的拷贝pod文件到宿主机本地目录
    kubectl cp /tmp/foo <some-pod>:/tmp/bar -c <specific-container> # 对于多容器pod,用-c指定容器名

    节点管理

    kubectl cordon my-node       
    # 标记 my-node 为 unschedulable,禁止pod被调度过来。注意这时现有的pod还会继续运行,不会被驱逐。
    kubectl uncordon my-node 
    # 与cordon相反,标记 my-node 为 允许调度。
    kubectl drain  my-node
    # drain字面意思为排水,实际就是把my-node的pod平滑切换到其他node,同时标记pod为unschedulable,也就是包含了cordon命令。
    # 但是直接使用命令一般不会成功,建议在要维护节点时,加上以下参数:
    kubectl drain my-node  --ignore-daemonsets  --force  --delete-local-data  
    # --ignore-daemonsets 忽略daemonset部署的pod
    # --force 直接删除不由workload对象(Deployment、Job等)管理的pod
    # --delete-local-data  直接删除挂载有本地目录(empty-dir方式)的pod
  • 相关阅读:
    变量
    词频统计
    Python文件处理
    python面试题
    函数及组合数据类型
    位(bit)、字节(byte)、字符、编码之间的关系
    程序的控制结构
    Python:turtle库的使用及图形绘制
    Dynamics 365 CRM Connected Field Service 不能接收IoT Alert
    Dynamics 365 CRM 部署 Connected Field Service
  • 原文地址:https://www.cnblogs.com/uestc2007/p/15603579.html
Copyright © 2020-2023  润新知