K8s kubectl 常用命令总结
我们已经知道kubernetes的常用术语和一些思想,要想进行二次开发,或者简单的说跑起来,运行一个小实例,那就要求我们需要对ta的常用操作相当的熟悉。入手了解kubectl是非常快速的一个方式,下面,我们就来看看kubectl的命令行操作的常用方式。
1.kubectl用法详解
kubectl [command] [Type] [NAME] [flags]
- command: 子命令,用于操作kubernetes集群资源对象的命令,例如:create, delete, describe, get, apply等等
- TYPE: 资源对象的类型,区分大小写,能以单数,复数或者简写形式表示。例如以下3中TYPE是等价的。
kubectl get pod pod1
kubectl get pods pod1
kubectl get po pod1
- NAME:资源对象的名称,区分大小写。如果不指定名称,系统则将返回属于TYPE的全部对象的列表,例如:kubectl get pods 将返回所有pod的列表
- flags: kubectl 子命令的可选参数,例如使用 -s 指定api server的url地址而不用默认值。
kubectl可操作的资源对象类型以及缩写:
在一个命令行中也可以同时对多个资源对象进行操作,以多个TYPE和NAME的组合表示,示例如下:
获取多个pod的信息:
kubectl get pods pod1 pod2
获取多种对象的信息:
kubectl get pod/pod1 rc/rc1
同时应用多个YAML文件,以多个-f file参数表示:
kubectl get pod -f pod1.yaml -f pod2.yamlkubectl create -f pod1.yaml -f rc1.yaml -f service1.yaml
2.kubectl子命令详解
kebectl的子命令非常丰富,涵盖了对kubernetes集群的主要操作,包括资源对象的创建、删除、查看、修改、配置、运行等,详细的子命令如表2.10所示:
3.kubectl参数列表
Kubectl命令行的公共启动参数如下所示:
4.Kubectl 输出格式
kubectl命令可以用多种格式对结果进行显示,输出的格式通过-o参数指定:
5.kubectl操作示例
1.根据yaml配置文件一次性创建service和rc
kubectl create -f my-service.yaml -f my-rc.yaml
2.根据目录下所有.yaml、.yml、.json文件的定义进行创建操作
kubectl create -f <directory>
3.查看所有Pod列表
kubectl get pods
4.查看rc和service列表
kubectl get rc,service
5.显示Node的详细信息
kubectl describe nodes <node-name>
6.显示Pod的详细信息
kubectl describe pods/<pod-name>
7.显示由RC管理的Pod信息
kubectl describe pods <rc-name>
8.删除基于pod.yaml文件定义的Pod
kubectl delete -f pod.yaml
9.删除所有包含某个label的Pod和Service
kubectl delete pods,services -l name=<label-name>
10.删除所有Pod
kubectl delete pods --all
11.在Pod的容器里执行date命令,默认使用Pod中的第1个容器执行
kubectl exec <pod-name> date
12.指定Pod中某个容器执行date命令
kubectl exec <pod-name> -c <container-name> date
13.以bash方式登陆到Pod中的某个容器里
kubectl exec -it <pod-name> -c <container-name> /bin/bash
14.查看容器输出到stdout的日志
kubectl logs <pod-name>
15.跟踪查看容器的日志,相当于tail -f命令的结果
kubectl logs -f <pod-name> -c <container-name>