(见底部更新...)
我已经为 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 红宝石
第二个问题是数据输入方法的正确配置(我想收集的每个单独的指标一个,即使它们都使用相同的脚本),它提供数据模板的数据源(反之亦然,我m 仍然不清楚)哪个提供图形模板,这些模板需要分配给设备,然后添加到图形树中。总而言之,这是文档垃圾的重大崩溃,我希望永远不必再这样做。
更新#5:我已经在 GitHub http://github.com/trak3r/cacti-beanstalkd-script上分享了我的脚本
当我尝试调试自定义脚本时,我发现让脚本在每次运行时将一些信息附加到临时文件中会很有帮助。这样我就可以确保它被称为我期望的方式。诸如 cmd 行参数、环境以及它将返回什么值之类的东西。您可能还希望将 stderr 重定向到日志文件以捕获脚本的错误输出。
我看到你做了一个数据输入法和一个图表模板;您是否还制作了数据模板?