kubectl命令行语法以下:node
kubectl [command] [type] [name] [flags]
参数说明: command:子命令,用于管理和操做Kubernetes集群资源对象的命令。例如:create、delete、describe、get、apply等。 type:资源对象的类型,区分大小写,能以单数形式、复数形式或者简写形式表示。 kubectl get pod pod1 # 单数形式 kubectl get pods pod1 # 复数形式 kubectl get po pod1 #简写形式 name:资源对象的名称,区分大小写,若是不指定名称,则系统返回属于type的所有对象的列表。 flags:kubectl子命令的可选参数,例如使用“-s”指定apiserver的URL地址而不用默认值。
表1:kubectl可操做的资源对象类型json
资源对象的名称 | 缩写 |
---|---|
clusters | |
componentstatuses | cs |
configmaps | cm |
daemonsets | ds |
deployments | deploy |
endpoints | ep |
events | ev |
horizontalpodautoscalers | hpa |
ingresses | ing |
Jobs | |
limitranges | limits |
nodes | no |
namespaces | ns |
networkpolicies | |
statefulsets | |
persistentvolumeclaims | pvc |
persistentvolumes | pv |
pods | po |
podsecuritypolicies | psp |
podtemplates | |
replicasets | rs |
replicationcontrollers | rc |
cronjob | |
secrets | |
serviceaccounts | |
service | svc |
storageclasses | sc |
thirdpartyresources |
kuberctl的子命令很是丰富,包括资源对象的建立、删除、查看、修改、配置、运行等。
表2:kubectl子命令语法api
表3:kubectl命令行的公共启动参数
每一个子命令(如create、delete、get等)还有特定的flags参数,能够经过kubectl [command] --help命令进行查看。bash
kubectl命令能够用多种格式对结果进行显示,输出的格式经过-o参数指定:app
kubectl [command] [TYPE] [NAME] -o=<output_format>
表4:kubectl命令的输出格式
经常使用的输出格式示例以下:
(1)显示Pod的更多信息ide
kubectl get pod <pod-name> -o wide
(2)以yaml格式显示Pod的详细信息jsonp
kubectl get pod <pod-name> -o yaml
(3)以自定义列名显示Pod的信息spa
kubectl get pod <pod-name> -o=custom-columns=NAME:.metadata.name,RSRC:.metadata.resourceVersion
(4)基于文件的自定义列名输出命令行
kubectl get pods <pod-name> -o=custom-columns-file=template.txt
template.txt文件的内容为: NAME RSRC metadata.name metadata.resourceVersion
输出结果为: NAME RSRC Pod-name 52305
另外,还能够将输出结果按某个字段排序,经过--sort-by参数以jsonpath表达式进行指定:日志
kubectl [command] [TYPE] [NAME] --sort-by=<jsonpath_exp>
例如,按照名字进行排序
kubectl get pods --sort-by=.metadata.name
一、根据yaml配置文件一次性建立service和rc
kubectl create -f my-service.yaml -f my-rc.yaml
二、根据<directory>目录下全部.yaml、.yml、.json文件的定义进行建立操做
kubectl create -f <directory>
三、查看全部Pod列表
kubectl get pods
四、查看rc和service列表
kubectl get rc,service
五、显示Node的详细信息
kubectl describe nodes <node-name>
六、显示Pod的详细信息
kubectl describe pods/<pod-name>
七、显示由RC管理的Pod信息
kubectl describe pods <rc-name>
八、删除基于pod.yaml文件定义的Pod
kubectl delete -f pod.yaml
九、删除全部包含某个label的Pod和Service
kubectl delete pods,services -l name=<label-name>
十、删除全部Pod
kubectl delete pods --all
十一、在Pod的容器里执行date命令,默认使用Pod中的第1个容器执行
kubectl exec <pod-name> date
十二、指定Pod中某个容器执行date命令
kubectl exec <pod-name> -c <container-name> date
1三、以bash方式登录到Pod中的某个容器里
kubectl exec -it <pod-name> -c <container-name> /bin/bash
1四、查看容器输出到stdout的日志
kubectl logs <pod-name>
1五、跟踪查看容器的日志,至关于tail -f命令的结果
kubectl logs -f <pod-name> -c <container-name>