Kubernetes学习笔记(三)
[查看某个node上的pod]
> kubectl get pods -o wide --namespace=kube-system | grep master-0 #node master-0上kube-system里的pod
> kubectl get pods --field-selector=spec.nodeName='master-0' --all-namespaces #node master-0上的pod
或者> kubectl describe node node-0
或者 > kubectl get pod --field-selector spec.nodeName='master-0' --all-namespaces
> kubectl get node | awk '{print $1}' | xargs -t -i kubectl get pods --field-selector spec.nodeName={} --all-namespaces #列出每个node上的所有pod
[获取pod的UID,podIP等信息]
注:目录/var/log/pods下文件夹名字是pod的UID; 获取container详细信息时,里面包含所属pod的UID.
1) 方法一:jq
>kubectl get pods -n <namespace> <pod-name> -o jsonpath='{.metadata.uid}'
>kubectl get pod -n <namespace> <pod-name> -o json | jq '.metadata.uid'
From <https://stackoverflow.com/questions/57799684/how-do-i-get-the-pod-id-in-kubernetes>
2) 方法二:grep
>kubectl get pods -n <namespace> <pod-name> -o yaml | grep uid
3) 方法三:custom-column
>kubectl get pods -n <namespace> -o custom-columns=PodName:.metadata.name,PodUID:.metadata.uid #推荐
(注:支持这些参数: metadata.name, metadata.namespace, spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP)
根据需要灵活使用,如下例子:
>kubectl get pods -A -o custom-columns=NodeName:.spec.nodeName,PodName:.metadata.name,PodUID:.metadata.uid | grep "nodename"
>kubectl get pods -A -o custom-columns=PodName:.metadata.name,PodUID:.metadata.uid,PodIP:.status.podIP
>kubectl get pods -n <namespace> -o custom-columns=PodName:.metadata.name,PodUID:.metadata.uid,PodIP:.status.podIP
>kubectl get pods -n <namespace> -o custom-columns=PodName:.metadata.name,PodIP:.status.podIP,hostIp:.status.hostIP
>kubectl get pods -n <namespace> -o custom-columns=NodeName:.spec.nodeName,PodName:.metadata.name,PodIP:.status.podIP,hostIp:.status.hostIP
>kubectl get pods -n <namespace> -o custom-columns=NodeName:.spec.nodeName,PodName:.metadata.name,Service:spec.serviceAccountName
From <https://stackoverflow.com/questions/57799684/how-do-i-get-the-pod-id-in-kubernetes>
>kubectl get pod -A -o=jsonpath='{range.items[*]}{.metadata.name}{"\t"}{.status.podIP}{"\n"}{end}' #pod名字及IP地址信息
>kubectl get po $POD_NAME -n $NAMESPACE -o=jsonpath='{range.items[*]}{.metadata.name}{"\t"}{.status.podIP}{"\n"}{end}' #该指令无效
[获取pod的container和image信息]
1) 查看pod里面的container:
>kubectl describe pod xxx
2) 获取pod里的业务容器:
>kubectl get pod <pod name> -o jsonpath={.spec.containers[*].name} |xargs -n 1
例如: kubectl get pod csi-cinder-controllerplugin-0 -n kube-system -o jsonpath={.spec.containers[*].name}|xargs -n 1
3) 获取pod里的Initial容器:
>kubectl get pod <pod name> -o jsonpath={.spec.initContainers[*].name}
4) 获取container id和image信息:
>kubectl get pod <pod name> -o jsonpath='{.status.containerStatuses[*].containerID}' |xargs -n 1 #获取某个pod的containerID信息
>kubectl get pod <pod name> -o custom-columns=CONTAINER:.spec.containers[0].name,IMAGE:.spec.containers[0].image #获取某个pod的index=0的container和image信息
>kubectl get pod <pod name> -o custom-columns=PodName:.metadata.name,CONTAINER:.spec.containers[:].name,IMAGE:.spec.containers[:].image #获取某个pod的所有container和image信息
>kubectl get pod -n <namespace> -o custom-columns=PodName:.metadata.name,CONTAINER:.spec.containers[:].name,IMAGE:.spec.containers[:].image #获取某个namespace的所有container和image信息
>kubectl get pod -A -o custom-columns=PodName:.metadata.name,CONTAINER:.spec.containers[:].name,IMAGE:.spec.containers[:].image #获取所有pod的container和image信息
>kubectl get pods --all-namespaces -o jsonpath='{range .items[*]}{"pod: "}{.metadata.name}{"\n"}{range.status.containerStatuses[*]}{"\tname: "}{.containerID}{"\n\timage: "}{.image}{"\n"}{end}'
参考文档:
how to get the container id in pod? · Issue #50309 · kubernetes/kubernetes · GitHub
Expose Pod Information to Containers Through Files | Kubernetes
5) List All Container Images Running in a Cluster
From <https://kubernetes.io/docs/tasks/access-application-cluster/list-all-running-container-images/>
>kubectl get pods -n <namespace> -o jsonpath="{.items[*].spec.containers[*].image}"|xargs -n 1 #某个命名空间的image
>kubectl get pods --all-namespaces -o jsonpath="{.items[*].spec.containers[*].image}"|xargs -n 1 #所有命名空间的image
>kubectl get pods -A -o=custom-columns='DATA:spec.containers[*].image' #所有pods的image
>kubectl get pods -n <namespace> -o=custom-columns='DATA:metadata.name,DATA:spec.containers[*].image' #pod及对应的image
>kubectl get pods --all-namespaces -o jsonpath='{range.items[*]}{"\n"}{.metadata.name}{":\t"}{range .spec.containers[*]}{.image}{", "}{end}{end}'|
sort #pod及对应的image
*****************************************************************************************
顺便推荐一个排障的流程图:
A visual guide on troubleshooting Kubernetes deployments (learnk8s.io)
Kubernetes学习笔记(三)的更多相关文章
- Kubernetes 学习笔记(一):基础概念
个人笔记,仅本人查阅使用,不保证正确. 零.微服务 微服务架构专注于应用解耦合,通过将应用彻底地组件化和服务化,每个微服务只包含一个非常小的功能,比如权限管理.日志收集等等.由这一组微服务组合起来,提 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- [Firefly引擎][学习笔记三][已完结]所需模块封装
原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读: 笔记三主要就是各个模块的封装了,这里贴 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- java之jvm学习笔记三(Class文件检验器)
java之jvm学习笔记三(Class文件检验器) 前面的学习我们知道了class文件被类装载器所装载,但是在装载class文件之前或之后,class文件实际上还需要被校验,这就是今天的学习主题,cl ...
- VSTO学习笔记(三) 开发Office 2010 64位COM加载项
原文:VSTO学习笔记(三) 开发Office 2010 64位COM加载项 一.加载项简介 Office提供了多种用于扩展Office应用程序功能的模式,常见的有: 1.Office 自动化程序(A ...
- Java IO学习笔记三
Java IO学习笔记三 在整个IO包中,实际上就是分为字节流和字符流,但是除了这两个流之外,还存在了一组字节流-字符流的转换类. OutputStreamWriter:是Writer的子类,将输出的 ...
- NumPy学习笔记 三 股票价格
NumPy学习笔记 三 股票价格 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.&l ...
- Learning ROS for Robotics Programming Second Edition学习笔记(三) 补充 hector_slam
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...
- Learning ROS for Robotics Programming Second Edition学习笔记(三) indigo rplidar rviz slam
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...
随机推荐
- ASP.NET Core - 依赖注入(四)
4. ASP.NET Core默认服务 之前讲了中间件,实际上一个中间件要正常进行工作,通常需要许多的服务配合进行,而中间件中的服务自然也是通过 Ioc 容器进行注册和注入的.前面也讲到,按照约定中间 ...
- Kronecker convolution 克罗内克卷积理解
在了解空洞卷积时候发现了Kronecker convolution是对空洞卷积的改进,于是学习了一下 ,原文连接:1812.04945v1.pdf (arxiv.org) 个人理解如下: 首先,对于一 ...
- TCP怎样保证可靠传输
TCP的可靠性保证 TCP主要提供了检验和,序列号/确认应答,超时重传,最大消息长度,滑动窗口控制等方法实现了可靠性传输. 检验和 通过检验和的方式,接收端可以检测出来数据是否有差错和异常,假如有差错 ...
- opc ua与opc da区别
opc ua与opc da区别_OPC,OPCDA,OPCUA傻傻搞不清楚,走过路过不妨看一看 转自:https://blog.csdn.net/weixin_39624774/article/det ...
- C#辗转相除法输出最大公约数
void main() { int r, m, n, t; scanf_s("%d\n%d", &m, &n); if (m < n) { t = m; m ...
- [UnityShader]说厌了的遮挡显示
首先是效果 这个其实有相当多的地方在说了,我就不嚼舌根了 大概原理:一个Shader两个Pass,第一个Pass不管深度,都渲染,但是不写入深度,第二个Pass几乎没有改动,因为后执行,会覆盖掉第一个 ...
- [Unity]利用Mesh绘制简单的可被遮挡,可以探测的攻击指示器
最近做一个小游戏的Demo,最终的效果是这样的 主要是利用Mesh绘制三角形作为显示,然后使用后处理来制作探灯,注意,性能一般,仅仅适合小游戏 分为3步 1:利用mesh绘制三角形,原理很简单,利用三 ...
- [jQuery]判断页面是否滚动到底部
方法1:判断可见高度+滚动高度是否等于内容高度 但经过测试UC.QQ.华为浏览器,这个方法不生效.(打印查因:可能由于屏幕缩放,可见高度和滚动高度会偏小. $(this).scroll(functio ...
- iOS 制作一个动态库
方式一 1.新建一个framework 命名为test 2.将build archive architecture only 改成 NO 3.将Mach-O Type 改成 static Lib ...
- element-ui组件Table排序(sort-by),某些数据无需排序
在列中设置 sortable 属性即可实现以该列为基准的排序, 接受一个 Boolean,默认为 false. 可以通过 Table 的 default-sort 属性设置默认的排序列和排序顺序. 可 ...