kubectl使用方式

参考:k8s官方教程

              kubectl常用命令总结

1.kubectl命令行工具

        1.1kubectl 创建和管理 Kubernetes 对象的3种方式

        

a.指令式命令

使用指令式命令时,用户可以在集群中的活动对象上进行操作。用户将操作传给 kubectl 命令作为参数或标志。

这是开始或者在集群中运行一次性任务的推荐方法。因为这个技术直接在活跃对象 上操作,所以它不提供以前配置的历史记录。

例子 

通过创建 Deployment 对象来运行 nginx 容器的实例:

kubectl create deployment nginx --image nginx

b.指令式对象配置

在指令式对象配置中,kubectl 命令指定操作(创建,替换等),可选标志和 至少一个文件名。指定的文件必须包含 YAML 或 JSON 格式的对象的完整定义。

例子

创建配置文件中定义的对象:

kubectl create -f nginx.yaml

删除两个配置文件中定义的对象:

kubectl delete -f nginx.yaml -f redis.yaml

通过覆盖活动配置来更新配置文件中定义的对象:

kubectl replace -f nginx.yaml

c.声明式对象配置

使用声明式对象配置时,用户对本地存储的对象配置文件进行操作,但是用户 未定义要对该文件执行的操作。 kubectl 会自动检测每个文件的创建、更新和删除操作。 这使得配置可以在目录上工作,根据目录中配置文件对不同的对象执行不同的操作。

例子

处理 configs 目录中的所有对象配置文件,创建并更新活跃对象。 可以首先使用 diff 子命令查看将要进行的更改,然后在进行应用:

kubectl diff -f configs/
kubectl apply -f configs/

递归处理目录:

kubectl diff -R -f configs/
kubectl apply -R -f configs/

2.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信息
1
2
3
创建资源(推荐用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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值