返回介绍

监控方案 - logstash-input-heartbeat方式

发布于 2020-06-28 10:03:42 字数 2810 浏览 1301 评论 0 收藏 0

缺少内部队列状态的监控办法一直是 logstash 最为人诟病的一点。从 logstash-1.5.1 版开始,新发布了一个 logstash-input-heartbeat 插件,实现了一个最基本的队列堵塞状态监控。

配置示例如下:

  1. input {
  2. heartbeat {
  3. message => "epoch"
  4. interval => 60
  5. type => "heartbeat"
  6. add_field => {
  7. "zbxkey" => "logstash.heartbeat",
  8. "zbxhost" => "logstash_hostname"
  9. }
  10. }
  11. tcp {
  12. port => 5160
  13. }
  14. }
  15. output {
  16. if [type] == "heartbeat" {
  17. file {
  18. path => "/data1/logstash-log/local6-5160-%{+YYYY.MM.dd}.log"
  19. }
  20. zabbix {
  21. zabbix_host => "zbxhost"
  22. zabbix_key => "zbxkey"
  23. zabbix_server_host => "zabbix.example.com"
  24. zabbix_value => "clock"
  25. }
  26. } else {
  27. elasticsearch { }
  28. }
  29. }

示例中,同时将数据输出到本地文件和 zabbix server。注意,logstash-output-zabbix 并不是标准插件,需要额外安装:

  1. bin/logstash-plugin install logstash-output-zabbix

文件中记录的就是 heartbeat 事件的内容,示例如下:

  1. {"clock":1435191129,"host":"logtes004.mweibo.bx.sinanode.com","@version":"1","@timestamp":"2015-06-25T00:12:09.042Z","type":"heartbeat","zbxkey":"logstash.heartbeat","zbxhost":"logstash_hostname"}

可以通过文件最后的 clock 和 @timestamp 内容,对比当前时间,来判断 logstash 内部队列是否有堵塞。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文