首页 > 数据库技术 > 详细

mongodb监控脚本

时间:2016-09-14 23:36:55      阅读:413      评论:0      收藏:0      [点我收藏+]

脚本涵盖两种监控mongo的方法:使用自带的mongostat工具查看,各个监控项的位置可能要按实际的mongostat输出进行调整;进入admin库,查看具体状态信息,可能需要验证。


完整步骤:

 1.创建用于监控的用户角色:mongo用户的权限按用户角色进行划分

> use admin 
> db.getRoles()
> db.createRole(
    { role:"mongostatRole",
     privileges:[{resource:{cluster:true},actions:["serverStatus"]}],
     roles:[]}
    )            //建立一个使用mongostat命令权限的用户角色

 2.创建系统监控角色

>  db.getUsers() 
> db.createUser(
    { user:"dbmon",
     pwd:"password",
     roles:[{role:"mongostatRole",db:"admin"}]}
    )

 3.编写脚本,mongodb_sts.sh

#!/bin/bash
host="127.0.0.1"
passwd="password"
rst=‘‘
case "$1" in
    conn)
        rst=`mongostat -n 1 -u dbbak -p $passwd --authenticationDatabase=admin|awk ‘NR==2 {print $(NF-1)}‘`
        ;;
    dirty)
        rst=`mongostat -n 1 -u dbbak -p $passwd --authenticationDatabase=admin|awk -F[\ ]+ ‘NR==2 {print $8}‘`
        ;;
    used)
        rst=`mongostat -n 1 -u dbbak -p $passwd --authenticationDatabase=admin|awk -F[\ ]+ ‘NR==2 {print $9}‘`
        ;;
    qr)
        rst=`mongostat -n 1 -u dbbak -p $passwd --authenticationDatabase=admin|awk -F[\ \|]+ ‘NR==2 {print $(NF-7)}‘`
        ;;
    qw)
        rst=`mongostat -n 1 -u dbbak -p $passwd --authenticationDatabase=admin|awk -F[\ \|]+ ‘NR==2 {print $(NF-6)}‘`
        ;;
    res)
        res=$(echo "db.serverStatus().mem" | mongo -u dbbak -p $passwd admin|awk -F[,\ ] ‘/"resident"/{print $3}‘)
        rst=$[res*1024*1024]
        ;;
    vsize)
        resize=$(echo "db.serverStatus().mem" | mongo -u dbbak -p $passwd admin|awk -F[,\ ] ‘/"virtual"/{print $3}‘)
        rst=$[resize*1024*1024]
        ;;
    *)
        echo "aaaaaaaaaaaa"
#       exit 5
esac
if [ -z $rst ];then
        echo 0
else
        echo $rst
fi

 4.脚本应用:cacti、zabbix等

本文出自 “11414123” 博客,转载请与作者联系!

mongodb监控脚本

原文:http://11424123.blog.51cto.com/11414123/1852783

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!