作者:张琪健V | 来源:互联网 | 2014-05-28 16:53
最近因为业务需求,上线了几台MongoDB服务器,需要做数据库监控。其实可选方案还是挺多的,比如官方的MMS、自己开发脚本等。我这里谈下Cacti监控MongoDB的方法。选择的Cacti插件为Percona提供的MongoDB监控模板,详细资料请参考官网http://www.percona.com/do
最近因为业务需求,上线了几台MongoDB服务器,需要做数据库监控。其实可选方案还是挺多的,比如官方的MMS、自己开发脚本等。我这里谈下Cacti监控MongoDB的方法。
选择的Cacti插件为Percona提供的MongoDB监控模板,详细资料请参考官网http://www.percona.com/doc/percona-monitoring-plugins/cacti/
mongodb-templates.html,官方下载地址为:http://www.percona.com/downloads/percona-monitoring-plugins/。
我提前谈下对这个模板的看法,说实话比较鸡肋,感觉作者开发并不用心,所以这里需要做二次开发进行相应的改造,使其稍微完美点,具体操作步骤如下:
1. 修改mongodb_cmdline函数,通过授权帐号密码、指定端口进行登录。
function mongodb_cmdline ( $options ) {
// return "echo \"db._adminCommand({serverStatus:1, repl:2})\" | mongo";
return "echo \"db._adminCommand({serverStatus:1, repl:2})\" | /usr/local/mongodb/bin/mongo admin --port $options[port2] --username flykite --password 123456";
}
2.
修改get_command_result函数,采用远程登录的方式,而非默认SSH的方式。(数据库本来就可以远程连接,搞不懂作者为什么选择SSH登录数据库服务器执行命令...)
// $final_cmd = $use_ssh ? "$ssh '$cmd'" : $cmd;
$final_cmd = "$cmd --host $options[host]";
3. 执行脚本进行测试,结果如下:
[@cacti scripts]# php ss_get_by_ssh.php --type mongodb --host 10.13.198.102 --port2 6666 --items jc,jd
jc:4 jd:5497683968
4. 如果是一台服务器有两个端口,需要复制两个Data Templates,如下:
5. 为了方便,也可以制作根据端口数量,制作不同的Host
Templates,这里省略。需要注意的是在Data Templates的配置中,一定要勾选Port2参数,如下:
6.
在添加Device设备的时候,如果勾选了MongoDB的模板,需要指定Port2参数,如下:
Cacti监控MongoDB配置基本就完成了,我们可以看下效果,如下:
进一步思考,如果访问MongoDB的账户密码不确定,也可以将其作为参数传入脚本中。MongoDB可以不指定完整路径,在环境变量中就可以了。