第240114期 - 监控

使用prometheus监控的看过来了!大一统监控探针cprobe

不知道大家目前监控是怎么做的,是不是prometheus外加一堆的exporter,或许还有一些自己开发的exporter。

用到最多的就是node_exporter、blackbox_exporter、redis_exporter、mysql_exporter、es_exporter等。

而cprobe的目标就是做到一个统一的采集器,目前已经实现了对mysql、redis、kakfa、blackbox的支持,可以说最常用到的都已经支持到了。

可以去尝试使用下,下面为具体介绍。

拨测监控

cprobe是一个由vmagent和多个exporter组成的混合体,它可以用来采集和发送各种类型的监控数据。cprobe的设计理念是将Prometheus的scrape功能和exporter的采集功能结合起来,形成一个统一的、可扩展的、易于部署的监控代理。

cprobe的主要特点有:

  • 支持多种监控数据源,如MySQL, Redis, Kafka, HTTP等。
  • 支持多种监控数据格式,如Prometheus, OpenTelemetry, InfluxDB等。
  • 支持多种监控数据目的地,如VictoriaMetrics, Thanos, Cortex等。
  • 支持多种监控数据转换,如标签添加、删除、重命名等。
  • 支持多种监控数据过滤,如白名单、黑名单、正则表达式等。
  • 支持多种监控数据聚合,如计数器、直方图、摘要等。
  • 支持多种监控数据采样,如固定间隔、自适应间隔等。
  • 支持多种监控数据压缩,如snappy, lz4, zstd等。
  • 支持多种监控数据加密,如TLS, mTLS等。
  • 支持多种监控数据认证,如Basic Auth, Bearer Token等。
  • 支持多种监控数据重试,如指数退避、随机抖动等。
  • 支持多种监控数据缓存,如内存、磁盘等。
  • 支持多种监控数据路由,如哈希、轮询、一致性哈希等。
  • 支持多种监控数据负载均衡,如权重、优先级、健康检查等。
  • 支持多种监控数据高可用,如故障转移、故障恢复等。

cprobe的安装和使用非常简单,只需要下载对应的二进制文件或者Docker镜像,然后配置好相关的参数,就可以启动cprobe并开始采集和发送监控数据。cprobe还提供了一个helm-chart,可以方便地在Kubernetes集群中部署cprobe。

cprobe是一个开源的项目,它的源码托管在GitHub上,欢迎感兴趣的开发者参与贡献。cprobe的作者是UlricQin,他是一位资深的监控领域的专家,曾经参与开发过Open-Falcon, Nightingale等知名的监控系统。

cprobe是一个值得关注的监控工具,它可以为用户提供一个全面的、灵活的、高效的监控解决方案,让用户可以更好地了解和管理自己的系统和服务。如果你对cprobe感兴趣,可以访问它的官方网站,或者在GitHub上给它一个星星。

开源地址:https://github.com/cprobe/cprobe