什么是kubernetes pod
在kubernetes
中,pod
是最小运行单位,在pod
运行不少于1个的“容器”,在pod
中的容器,会打通这部分容器的网络、存储,就像是在pod
内随意操作一样,其实核心原理是kubernetes
为这些容器左右namespace
和cgroups
的调整和打通,才会导致打通这些数据互相可以访问,这也是pause
容器存在的根本原因,
大概抽象展示出来是这样的。
为了方便,我们将kubernetes pod
后面简称为pod
。
pod简单操作
创建pod
这里铺垫一下部分信息,对于我们命令行客户端来说,我们会使用一个工具: kubectl
来进行和kubernetes API
通信,进而来控制k8s
集群,我们在创建pod
的过程中,会使用apply
参数来创建pod
我们来创建一个nginx pod
,其名称我们命名为pdudo-juejin-nginx-pod1
我们也可以写成json
描述符
不过,json
中不能写注释,这是比较不友好的,所以,我们一般均使用yaml
。
我们使用kubectl apply
来创建容器
使用kubectl get pods
显示pod信息 -o wide
显示为更为详细的
从上图可知,我们这个pod
已经被分配到了node1
上,我们可以去node1
看下容器信息
尝试访问pod
信息
查看pod日志
对于k8s
而言,查看pod
日志,一般由2种模式
- 查看
pod
内所有容器的日志 - 查看
pod
内某一容器的日志
使用kubectl logs pod_name
可以查看pod
内所有容器的日志
而使用-c
容器名称,则可以看到容器的日志
删除pod
在kubernetes
中,使用delete
来删除资源,这里指的资源不仅仅是pod
。
总结
pod
作为k8s
最核心的组件资源之一,其重要性不言而喻,我们好在通过一个小小的demo
终于算是探得pod
一小角,指的注意的是,虽然k8s
支持资源描述文件格式有json
和yaml
,但是对于配置文件而言,建议使用yaml
,因为它可以写注释,且格式清晰,只要你去学习了一下,就会感觉yaml
配置起来非常爽,而json
则不行,如果你不清晰yaml
或者json
不知道,怎么写,你可以使用kubectl explain pod
来协助你
它会告诉你,pod
版本是多少,有哪些参数,我们看到spec
是对象,我们可以使用命令kubectl explain pod.spec
继续往下看,是不是感觉清晰多了,不那么无所适从了。
那今天就这样咯。