当前位置: 首页 > news >正文

收集 Kubernetes 资源统计数据的新工具

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

零配置工具简化了信息收集,例如在某个命名空间中运行了多少个 pod。

最近我在纽约的 O'Reilly Velocity 就 Kubernetes 应用故障排除的主题发表了演讲,并且在积极的反馈和讨论的推动下,我决定重新审视这个领域的工具。结果,除了 kubernetes-incubator/spartakus 和 kubernetes/kube-state-metrics 之外,我们还没有太多的轻量级工具来收集资源统计数据(例如命名空间中的 pod 或服务的数量)。所以,我在回家的路上开始编写一个小工具 —— 创造性地命名为 krs,它是 Kubernetes Resource Stats 的简称 ,它允许你收集这些统计数据。

你可以通过两种方式使用 mhausenblas/krs:

直接在命令行(有 Linux、Windows 和 MacOS 的二进制文件),以及
在集群中使用 launch.sh 脚本部署,该脚本动态创建适当的基于角色的访问控制(RBAC) 权限。
提醒你,它还在早期,并且还在开发中。但是,krs 的 0.1 版本提供以下功能:

在每个命名空间的基础上,它定期收集资源统计信息(支持 pod、部署和服务)。
它以 OpenMetrics 格式公开这些统计。
它可以直接通过二进制文件使用,也可以在包含所有依赖项的容器化设置中使用。
目前,你需要安装并配置 kubectl,因为 krs 依赖于执行 kubectl get all 命令来收集统计数据。(另一方面,谁会使用 Kubernetes 但没有安装 kubectl 呢?)

使用 krs 很简单。下载适合你平台的二进制文件,并按如下方式执行:

$ krs thenamespacetowatch
# HELP pods Number of pods in any state, for example running
# TYPE pods gauge
pods{namespace="thenamespacetowatch"} 13
# HELP deployments Number of deployments
# TYPE deployments gauge
deployments{namespace="thenamespacetowatch"} 6
# HELP services Number of services
# TYPE services gauge
services{namespace="thenamespacetowatch"} 4

这将在前台启动 krs,从名称空间 thenamespacetowatch 收集资源统计信息,并分别在标准输出中以 OpenMetrics 格式输出它们,以供你进一步处理。

收集 Kubernetes 资源统计数据的新工具收集 Kubernetes 资源统计数据的新工具

krs 实战截屏

也许你会问,Michael,为什么它不能做一些有用的事(例如将指标存储在 S3 中)?因为 Unix 哲学。

对于那些想知道他们是否可以直接使用 Prometheus 或 kubernetes/kube-state-metrics 来完成这项任务的人:是的,你可以,为什么不行呢? krs 的重点是作为已有工具的轻量级且易于使用的替代品 —— 甚至可能在某些方面略微互补。

本文最初发表在 Medium 的 ITNext 上,并获得授权转载。

转载于:https://my.oschina.net/u/3585265/blog/2907070

相关文章:

  • 从零开始搭建物联网平台(7):使用Vue编写前端页面
  • Java 面向对象之构造方法
  • 我与Jetbrains的这些年
  • input实现文字超出省略号功能
  • 复习Javascript专题(四):js中的深浅拷贝
  • stackoverflow:为什么排序后的数组要比未排序数组运行快3倍以上?
  • 胡小林:把日常生活中碰到的事变成我们发露忏悔的机会
  • 分布式消息队列 Kafka
  • 网站如何做好SEO优化,该怎么选择SEO软件?
  • JAVA入门到精通-第67讲-sqlserver作业讲评
  • Tcp/Ip 三次握手与四次挥手
  • jQuery操作表格(table)的常用方法、技巧汇总
  • [转]GitLab Continuous Integration (GitLab CI/CD)
  • 实战开发正则归纳
  • Android Activity生命周期图解
  • [LeetCode] Wiggle Sort
  • 《深入 React 技术栈》
  • HTML5新特性总结
  • miniui datagrid 的客户端分页解决方案 - CS结合
  • Phpstorm怎样批量删除空行?
  • PHP的类修饰符与访问修饰符
  • React组件设计模式(一)
  • session共享问题解决方案
  • Vue组件定义
  • windows下mongoDB的环境配置
  • Yii源码解读-服务定位器(Service Locator)
  • 基于Javascript, Springboot的管理系统报表查询页面代码设计
  • 微信小程序开发问题汇总
  • 正则表达式
  • ​ 全球云科技基础设施:亚马逊云科技的海外服务器网络如何演进
  • ​软考-高级-信息系统项目管理师教程 第四版【第14章-项目沟通管理-思维导图】​
  • #Linux(权限管理)
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (C#)Windows Shell 外壳编程系列4 - 上下文菜单(iContextMenu)(二)嵌入菜单和执行命令...
  • (LNMP) How To Install Linux, nginx, MySQL, PHP
  • (Oracle)SQL优化技巧(一):分页查询
  • (定时器/计数器)中断系统(详解与使用)
  • (多级缓存)多级缓存
  • (二)学习JVM —— 垃圾回收机制
  • (接口自动化)Python3操作MySQL数据库
  • (论文阅读11/100)Fast R-CNN
  • (论文阅读笔记)Network planning with deep reinforcement learning
  • (转)c++ std::pair 与 std::make
  • ***汇编语言 实验16 编写包含多个功能子程序的中断例程
  • .NET delegate 委托 、 Event 事件,接口回调
  • .net framework 4.0中如何 输出 form 的name属性。
  • .net 中viewstate的原理和使用
  • .NET(C#) Internals: as a developer, .net framework in my eyes
  • .NET/C# 判断某个类是否是泛型类型或泛型接口的子类型
  • .NET国产化改造探索(一)、VMware安装银河麒麟
  • .NET开源的一个小而快并且功能强大的 Windows 动态桌面软件 - DreamScene2
  • /usr/bin/env: node: No such file or directory
  • @Transaction注解失效的几种场景(附有示例代码)
  • [ vulhub漏洞复现篇 ] AppWeb认证绕过漏洞(CVE-2018-8715)
  • [20161214]如何确定dbid.txt