如何在 Cacti 中调试数据输入方法脚本?

如何在 Cacti 中调试数据输入方法脚本?

(请参阅底部的更新...)

我已经为 Cacti 编写了一个数据输入方法脚本(使用 Ruby,从 beanstalkd 收集统计数据),它可以通过命令行运行(返回一个简单的整数,如此处所述)以 cacti 用户帐户运行时Cacti 工具本身不会收集任何数据,并且日志中也没有任何内容。

以下是数据输入方法的设置: Cacti 数据输入方法http://img.skitch.com/20091009-gh7g1kukn9yradj6y2iqrd5qm1.jpg

以下是结果图表(将其添加到主机的图表模板并运行足够长的时间来收集数据之后): 仙人掌图 http://img.skitch.com/20091009-xq1kn3qxkteb5hb11wtx6tbs8m.jpg

更新 #1:看起来 Cacti 可能正在剥离环境:

sudo su - cacti -c 'env -i /script/beanstat --host 10.11.12.13 --port 11300 --stat current-waiting'
/script/beanstat:4:in `require': 没有要加载的文件 -- ruby​​gems (LoadError)
    来自/script/beanstat:4

如果是这样,我该如何解决?

更新 #2此回应stackoverflow.com 上似乎已经解决了环境问题,但图表中仍然没有数据。

更新 #3:感谢@Heath 的建议,我提高了轮询器日志记录级别并捕获了此问题:

警告:CMD 的结果无效。部分结果:U

在谷歌上搜索“部分结果:U”是什么意思,但一直没找到。脚本只打印了一个整数值。

更新 #4:我终于让它工作了。核心问题是运行 shell 脚本时缺少环境。我必须通过在 Ruby 脚本前面添加以下几行来解决这个问题:

/bin/sh #!/bin/sh 复制代码
PATH=/usr/local/bin:$PATH
exec ruby​​ -x"/full/path/to/script/directory" $0"$@"
/usr/bin/env ruby

第二个问题是数据输入方法的正确配置(我想要收集的每个单独指标都有一个,尽管它们都使用相同的脚本),这些数据输入方法为数据源提供数据,数据源为数据模板提供数据(反之亦然,我仍然不清楚),数据模板为图形模板提供数据,图形模板需要分配给设备,然后添加到图形树中。总之,这是一个重大的失败,文档很差劲,我希望永远不要再遇到这种情况。

更新 #5:我已经在 GitHub 上分享了我的脚本http://github.com/trak3r/cacti-beanstalkd-script

答案1

当我尝试调试自定义脚本时,我发现让脚本在每次运行时将一些信息附加到临时文件很有帮助;这样我就可以确保它按照我预期的方式被调用。诸如 cmd 行参数、环境以及它将返回的值之类的信息。您可能还希望将 stderr 重定向到日志文件以捕获脚本中的错误输出。

我看到您制作了数据输入方法和图形模板;您还制作了数据模板吗?

相关内容