python写数据库脚本_使用python写一个监控mysql的脚本,在zabbix web上自定义模板

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

[root@cml 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)

假如执行测试时报以下错误:

[root@cml python]# python check_Mysql_custom.py slave_status

Traceback (most recent call last):

File "test.py", line 14, in

con = mysql.connect(user='zabbix',passwd='',port=3306)

File "/usr/local/lib/python2.7/site-packages/MySQLdb/__init__.py", line 81, in Connect

return Connection(*args, **kwargs)

File "/usr/local/lib/python2.7/site-packages/MySQLdb/connections.py", line 193, in __init__

super(Connection, self).__init__(*args, **kwargs2)

_mysql_exceptions.OperationalError: (2002, "Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)")

[root@cml python]# mkdir /var/lib/mysql

[root@cml python]# ln -s /tmp/mysql.sock /var/lib/mysql/mysql.sock

##测试一下脚本:

[root@cml python]# python check_Mysql_custom.py processlist

3

[root@cml python]# python check_Mysql_custom.py Connections

55876

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

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

[root@cml 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值:

要在Zabbix中配置自定义监控MySQLPython脚本,需要进行以下步骤: 1. 创建Python脚本 首先,您需要创建一个Python脚本来连接MySQL数据库并执行查询。脚本应该返回所需的监控数据。以下是一个示例Python脚本的代码: ```python import pymysql # MySQL连接参数 mysql_host = 'localhost' mysql_port = 3306 mysql_user = 'user' mysql_password = 'password' mysql_db = 'database' # 连接MySQL数据库 conn = pymysql.connect(host=mysql_host, port=mysql_port, user=mysql_user, password=mysql_password, db=mysql_db) # 执行查询 cursor = conn.cursor() cursor.execute("SELECT COUNT(*) FROM my_table") result = cursor.fetchone()[0] # 返回结果 print(result) ``` 请注意,此脚本连接到本地MySQL服务器,并查询名为“my_table”的表的行数。您可以根据自己的需要修改此脚本。 2. 将脚本复制到Zabbix服务器 将脚本复制到Zabbix服务器的某个位置,例如“/usr/lib/zabbix/externalscripts”。确保脚本可执行,并且Zabbix用户具有对该文件的读取权限。 3. 在Zabbix中配置ALScripts 在Zabbix中,ALScripts是用于执行外部脚本的功能。要配置ALScripts,请执行以下操作: - 转到Zabbix Web界面中的“管理”>“通用配置”>“外部脚本”。 - 单击“创建脚本”按钮。 - 输入脚本名称,例如“mysql_monitor.py”。 - 在“脚本命令”字段中输入Python脚本的完整路径,例如“/usr/lib/zabbix/externalscripts/mysql_monitor.py”。 - 单击“保存”按钮。 4. 创建Zabbix监控项 现在,您可以创建Zabbix监控项来监视MySQL数据库。要创建监控项,请执行以下操作: - 转到Zabbix Web界面中的“配置”>“主机”。 - 找到要监视的MySQL主机,并单击其名称。 - 单击“创建监控项”按钮。 - 在“名称”字段中输入监控项名称,例如“MySQL行数”。 - 在“键”字段中输入以下内容:`ALScript["mysql_monitor.py"]`。 - 在“类型”字段中选择“Zabbix采集器”。 - 单击“添加”按钮。 现在,您已经成功地配置了一个自定义监控MySQLPython脚本,并将其集成到Zabbix中。您可以在Zabbix中查看监控项的值,并设置警报以便在达到阈值时通知您。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值