mongodb监控脚本
短信预约 -IT技能 免费直播动态提醒
脚本涵盖两种监控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等
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341