使用python写一个监控mysql的脚本,在zabbix web上加上模板

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用python写一个监控mysql的脚本,在zabbix web上加上模板相关的知识,希望对你有一定的参考价值。

使用python写一个监控mysql的脚本,在zabbix web上加上模板:


##先使用MySQLdb的接口关联数据库。

[[email protected] python]# cat check_Mysql_custom.py
#!/usr/local/bin/python
'''author = chenmingle'''
'''Description:get mysql status'''
import os
import sys
try:
    import MySQLdb as mysql
except Exception, e:
    print e
    print "pip install MySQL-python"
    sys.exit(1)
con = mysql.connect(host='localhost',user='root',passwd='passwd',)
def processlist():
cur = con.cursor()
sql1 = 'show processlist'
a = str(cur.execute(sql1))
print a
def slave_status():
        cur = con.cursor()
        sql2 = cur.execute('show status like "%Slave_running%";')
        status2 = str(cur.fetchall())
        check2 = status2.split("'")[3]
        if check2 == 'ON':
                print 0
        else:
                print 1
def show_status(type):
cur = con.cursor()
b = cur.execute('show status like "%s";' %(type))
for i in cur.fetchall():
cat = str(i)
check = str(cat.split("'")[3])
print check
def main(type):
   if type == 'processlist':
processlist()
   elif type == 'slave_status':
slave_status()
   else:
show_status(type)
if __name__ == '__main__':
    try:
        type = sys.argv[1]
    except Exception, e:
        print "Usage: python %s type" % sys.argv[0]
        sys.exit(1)
    main(type)


##测试一下脚本:

[[email protected] python]# python check_Mysql_custom.py processlist
3
[[email protected] python]# python check_Mysql_custom.py Connections
55876


##测试显示所有在mysqlshow status的都可以输出信息出来:



##写一个模板配置文件(自定义key值):

[[email protected] zabbix_agentd.d]# cat Mysql_Custom.conf
UserParameter=mysql.Custom[*],/usr/local/bin/python /home/python/check_Mysql_custom.py $1


##zabbix web界面上加入模板: 

技术分享图片

##增加一个Appaliactions:

技术分享图片


##加入item值: 

技术分享图片

以上是关于使用python写一个监控mysql的脚本,在zabbix web上加上模板的主要内容,如果未能解决你的问题,请参考以下文章

Python脚本监控mysql数据库,Python脚本监控mongo数据库

Zabbix监控Oracle 连接数

python 监控mysql脚本

python脚本 监控MySQL slave 状态

python 写一个类似于top的监控脚本

一个监控挂载盘的python脚本