vlambda博客
学习文章列表

五个关键点,让kubernetes跑起来

五个关键点,让kubernetes跑起来
来源 | 三日凌空
| 故事凌
头图 | 付费下载于视觉中国

昨天,我们已经知道kubernetes的常用术语和一些思想, 要想进行二次开发, 或者简单的说跑起来,运行一个小实例,那就要求我们需要对ta的常用操作相当的熟悉。入手了解kubectl是非常快速的一个方式,下面,我们就来看看kubectl的命令行操作的常用方式。

五个关键点,让kubernetes跑起来

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的列表

kubectl可操作的资源对象类型以及缩写:
五个关键点,让kubernetes跑起来
一个命令行中也可以同时对多个资源对象进行操作,以多个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.yaml
kubectl create -f pod1.yaml -f rc1.yaml -f service1.yaml

五个关键点,让kubernetes跑起来

kubectl 子命令详解


kebectl的子命令非常丰富,涵盖了对kubernetes集群的主要操作,包括资源对象的创建、删除、查看、修改、配置、运行等,详细的子命令如表2.10所示:
五个关键点,让kubernetes跑起来

五个关键点,让kubernetes跑起来

kubectl参数列表


Kubectl命令行的公共启动参数如下所示:
五个关键点,让kubernetes跑起来

五个关键点,让kubernetes跑起来

Kubectl 输出格式


kubectl命令可以用多种格式对结果进行显示,输出的格式通过-o参数指定:
五个关键点,让kubernetes跑起来

五个关键点,让kubernetes跑起来

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>
更多阅读推荐