• kubectl常用命令总结


    查看集群和版本相关信息

    kubectl version				//显示客户端和服务器侧版本信息
    kubectl api-versions		//列出当前版本的kubernetes的服务器端所支持的api版本信息
    kubectl cluster-info		//获取k8s集群信息
    kubectl config view         //获取k8s集群管理配置信息,也就是 .kube/config 文件内容
    

    复制文件到容器

    kubectl cp fileName podName:/fileName	//复制文件到pod的指定目录,也可从容器中复制文件到外部
    

    获取帮助详细信息

    kubectl explain po			//查看帮助信息和help类似,尤其是资源清单的结构字段信息
    //查看帮助信息,资源下的cpu和memory等,每个配置项都有详细的网页手册地址
    kubectl explain Deployment.spec.template.spec.containers.resources
    

    常用获取资源方式

    kubectl get pods			//查看pod信息
    kubectl get pods -wide		//已监控方式查看pod信息,有新的创建和销毁会立刻打印出来
    kubectl get pods -o wide	//查看pod详细信息
    kubectl get nodes -o wide	//查看node详细信息
    kubectl get namespaces		//列出所有的namespace
    kubectl get rc,service      //查看rc和service列表
    kubectl get deployment		//获取指定控制器pod信息
    kubectl get pods -n kube-system  //查看kube-system命名空间中pod信息
    kubectl get pods/podName -o yaml  //查看pod的yaml信息
    

    描述资源

    kubectl describe node nodeName 			//获取详细资源清单信息(包括CPU和Memory)
    kubectl describe po podName 			//获取详细资源清单信息(包括错误信息和实时状态)
    

    查看日志

    kubectl logs podName -f					//或者指定pod的日志信息
    

    进入容器

    kubectl exec -it podName sh				//进入pod容器,但是对权限要求也较多
    kubectl exec -it podName -c containerName bash   //通过bash获得Pod中某个容器的TTY,相当于登录容器
    kubectl attach podName					//获取实时的logs信息
    

    创建资源(推荐用apply)

    kubectl create/apply -f yamls/sonar.yaml 			//根据yaml文件创建容器
    kubectl create/apply -f yamls/					//多个yaml文件创建容器
    kubectl create/apply -f my-service.yaml -f my-rc.yaml //根据yaml配置文件一次性创建service和rc
    

    删除资源

    kubectl delete -f yamls/sonar.yaml 			//删除指定pod 
    kubectl delete -f yamls/					//删除多个pod 
    kubectl delete pods podName					//删除指定pod 
    kubectl delete pod podName --force --grace-period=0    //强制删除pod
    kubectl delete deployment ControllerName	//有控制器的pod不能直接删除,需先删除其控制器
    kubectl delete pods,services -l name=labelName  //删除所有包含某个label的Pod和service
    kubectl delete pods --all                   //删除所有Pod
    

    标签匹配

    kubectl get pods --show-labels
    kubectl get pods --show-labels -l env=dev,tie=front    //多个标签同时满足条件
    kubectl get pods --show-labels -l 'env in (dev,test)'    [in,notin]
    kubectl label pods podName env=test      //设置标签 env=test
    kubectl label pods podName env=test --overwrite     //若env标签存在,强制设置标签 env=test
    kubectl lable pods podName env-       //删除podname中env标签
    

    暴露服务,也就是创建service

    kubectl expose pod podName [--port=80 --target-port=8000]
    kubectl expose deployment deployName [--port=80 --target-port=8000]
    

    [自动]扩缩容

    kubectl scale deployment deployName --replicas=3               //执行扩缩容Pod的操作
    kubectl autoscale deployment deployName --min=2 --max=10       //设置pod数量在2到10之间
    kubectl autoscale deployment deployName --max=5 --cpu-percent=80           //pod数量在1到5之间,目标CPU利用率为80%
    

    在线设置镜像版本

    kubectl set image deployment/nginx nginx=nginx:1.9.1    //设置nginx镜像为1.9.1版本
    kubectl edit deployment/nginx                           //编辑yaml文件修改
    kubectl rolling-update deployment deployName -f redis-rc.update.yaml    //执行滚动升级操作
    #官网滚动更新图
    https://kubernetes.io/images/docs/kubectl_rollingupdate.svg
    

    升级和回滚操作

    kubectl rollout history deployment deployName                //显示deployment的详情
    kubectl rollout history deployment deployName --revision=3   //显示版本3 deployment的详情
    kubectl rollout undo eployment/deployName                    //回滚到上一个版本
    kubectl rollout undo eployment/deployName --to-revision=3    //回滚到第3个版本
    kubectl rollout undo --dry-run=true eployment/deployName     //回滚到上一个版本,调试但不执行
    

    管理多集群

    kubectl cluster-info           //获取k8s集群信息
    kubectl config view            //获取k8s集群管理配置信息,也就是 .kube/config 文件内容
    kubectl config get-contexts    //查看集群名称的context
    kubectl config set-context 上下文名称 --user=minikube --cluster=minikube --namespace=demo  //设置上下文
    kubectl config set current-context minikube   //切换到名称为 minikube 的集群中
    kubectl config use-context minikube           //切换到名称为 minikube 的集群中
    

    设置集群角色

    kubectl label nodes test1 node-role.kubernetes.io/master=       //设置 test1 为 master 角色
    kubectl label nodes 192.168.0.92 node-role.kubernetes.io/node=    //设置 test2 为 node 角色
    kubectl taint nodes test1 node-role.kubernetes.io/master=true:NoSchedule   //设置 master 一般情况下不接受负载
    kubectl taint nodes test1 node-role.kubernetes.io/master-        //master运行pod
    kubectl taint nodes test1 node-role.kubernetes.io/master=:NoSchedule   //master不运行pod
    

    设置kubectl shell命令自动补全

    kubectl completion -h
    sudo yum -y install bash-completion
    source /usr/share/bash-completion/bash_completion
    type _init_completion
    echo 'source <(kubectl completion bash)' >> ~/.bashrc
    source ~/.bashrc
  • 相关阅读:
    FSLIB.NETWORK 简易使用指南
    在CentOS上安装owncloud企业私有云过程
    用于ViEmu的重置为试用状态的Python脚本
    Microsoft.Office.Interop.Excel 报错
    FineUIMvc表格数据库分页,使用CYQ.Data组件
    如何在已有项目中引入FineUIMvc
    按键精灵-常用脚本命令汇集
    微信分享代码
    [教程] 【原创】媒体扫描耗电的彻底解决办法(申精)
    Less学习笔记
  • 原文地址:https://www.cnblogs.com/cheyunhua/p/14230058.html
Copyright © 2020-2023  润新知