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 podName -n namespace -c 容器名
    
    # 查看所有名称空间的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
    
    #查看yaml里面字段模板参数
    kubectl explain pod

    #查看pod的日志信息
    kubectl logs    ingress-nginx-controller-np6z4 -n ingress-controller

操作类命令:

    # 创建资源
    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  #动态伸缩【根据资源类型和名称伸缩,其他配置「如:镜像版本不同」不生效】    

    #创建yaml文件模板
    kubectl create deployment web --image=nginx -o yaml --dry-run > hello.yaml  #创建yaml文件模板
    kubectl get deploy nginx -o=yaml --export > nginx.yaml #导出yaml文件模块
    kubectl expose deployment web1 --port=80 --target-port=80 --type=NodePort --dry-run -o yaml > service.yaml #导出svc模板
    
    
helm命令操作:

    #添加仓库
    helm repo add 仓库名  仓库地址
    helm repo add stable http://aliacs-k8s-cn-hangzhou.oss-cn-hangzhou.aliyuncs.com/app/charts/ 
    helm repo add incubator http://aliacs-k8s-cn-hangzhou.oss-cn-hangzhou.aliyuncs.com/app/charts-incubator/
    #更新仓库
    helm repo update
    #查看全部仓库
    helm repo list
    #查看某个应用
    helm search repo 仓库名
    #删除我们添加的源
    helm repo remove 仓库名
    #安装
    helm install ui stable/weave-scope #{ui代表安装后取的名字(随机),stable/weave-scope后面的是仓库的包名}
    helm list                          #查看安装之后的状态
    helm status ui                     #查看更新具体的信息
    
    #如何自己创建chart
    helm create mychart 
    helm install web1 mychart #执行命令创建
    helm upgrade web1 mychart #修改了mychart中的东西后,就可以进行升级操作    
    helm lint mychart          #测试charts语法
    helm template mychart     #查看生成的yaml文件
    helm package mychart      #应用打包成tgz文件
    helm hist web1            #查看历史版本
    helm rollback web1 1      #应用回滚
    helm delete web1          #应用删除
    

    
    

    
    


    

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值