什么是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继续往下看,是不是感觉清晰多了,不那么无所适从了。
那今天就这样咯。










