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

Tef*_*Ted 8 scripting cacti

(见底部更新...)

我已经为 Cacti 编写了一个数据输入方法脚本(在 Ruby 中,用于从 beanstalkd 收集统计信息)并且它在作为 cacti 用户帐户运行时从命令行工作(返回一个简单的整数,如文档所述),但是Cacti 工具本身没有收集任何数据,日志中也没有任何内容。

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

这是生成的图表(在将其添加到主机的图表模板并运行足够长的时间以收集数据之后): Cacti Graph 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': 没有要加载的文件——rubygems (LoadError)
    来自 /script/beanstat:4

如果是这种情况,我该如何解决?

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

更新 #3:感谢@Heath 的建议,我提高了轮询器日志记录级别并发现了这一点:

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

谷歌搜索“部分结果:U”的意思没有任何运气。该脚本只打印一个整数值。

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

#!/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上分享了我的脚本

Hea*_*ath 4

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

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