k8s命令汇总

pod的内存yucpu使用查看方法:
kubectl top pod podName -n namespaceName


kubuctl修改当前命名空间
kubectl config set-context $(kubectl config current-context) --namespace=peiyou-xiaohoucode

事件相关
kubectl get events -A // 获取命名空间所有
kubectl describe deployment coding-judge-judge-test // 获取某个deployment的详情,包括事件

资源创建
kubectl create -f my-service.yaml -f my-rc.yaml #一次性创建service和rc
kubectl create -f <directory> #路径下所有的yaml yml json进行文件的创建

资源查看
kubectl get pods #查看所有pod列表
kubectl get service,rc

资源描述(详情)
kubectl describe nodes <node-name> #获取某规则资源的详情
kubectl describe pods/<pod-name> 
kubectl describe pods <rc-name>

删除资源
kubectl delete -f  pod.yml #基于yaml的定义删除pod
kubectl delete pods,services -l name=<label-name> #基于标签名称删除pod和service
kubectl delete pods -all #删除所有pod

执行容器命令
kubectl exec <pod-name> date #在某个pod中执行命令,默认第一个容器
kubectl exec <pod-name> -c <contianer-name> date #在指定pod的指定容器中执行
kubectl exec <pod-name> -c <contianer-name>  /bin/bash

获取容器日志
kubectl logs <pod-name>
kubectl logs -f <pod-name> -c <container-name>

kubectl create -f 我的配置文件
基于yaml文件创建对象

kubectl get pods -l app=nginx
从 Kubernetes 里面获取(GET)指定的 API 对象。可以看到,在这里我还加上了一个 -l 参数,即获取所有匹配 app: nginx 标签的 Pod。

kubectl describe pod nginx-deployment-67594d6bf6-9gdvr
kubectl describe 命令,查看一个 API 对象的细节

kubectl get deployments

kubectl describe  deployment nginx-deployment

#推荐的yaml文件执行方式
kubectl apply -f nginx-deployment.yaml

进入Pod当中
$ kubectl exec -it nginx-deployment-5c678cfb6d-lg9lw -- /bin/bash
# ls /usr/share/nginx/html

删除这个 Nginx Deployment
$ kubectl delete -f nginx-deployment.yaml

查看集群和版本相关信息

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