此监控是由真实的项目平台,从MySQL统计成功率来进行监控

1、创建存放监控的Python程序的目录

[root@MySQL-Slave ~]# mkdir /data/zabbix-4.4.3/script

2、编写监控的程序

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2020/1/2 17:03
# @Author  : suk
# @File    : monitor_username.py
# @Software: PyCharm

import pymysql
import sys
import datetime

if __name__ == '__main__':

    import datetime

    today = datetime.date.today()
    formatted_today = today.strftime('%Y%m%d')

    # 生产库
    db = pymysql.connect(host='数据库的IP地址',
                         port=3306,
                         database='数据库的名字',
                         user='数据库用户名',
                         password='数据库的密码')

    ec_user_channel = db.cursor(cursor=pymysql.cursors.DictCursor)
    ec_user_channel.execute("""
SELECT
    SUM( IF ( status_ != 13, 1, 0 ) ) AS 'sendFailCount',
    SUM( IF ( status_ = 13, 1, 0 ) ) AS 'sendSuccessCount'
FROM
    xxxxx_""" + formatted_today + """
WHERE
    user_id = ( SELECT uid FROM ec_user WHERE username = %s )""", args=(sys.argv[1],))
    rows = ec_user_channel.fetchone()

    if (rows.get('sendSuccessCount') and rows.get('sendFailCount')) or (rows.get('sendSuccessCount') != 0 and rows.get('sendFailCount') == 0):
        print(
            '%02f' % (rows.get('sendSuccessCount') / (rows.get('sendFailCount') + rows.get('sendSuccessCount')) * 100))
        sys.exit(0)
    else:
        print(0)
        sys.exit(1)
monitor_success_rate.py
默认脚本是以zabbix用户运行的,所有需要授权
[root@MySQL-Slave ~]# chown -R zabbix.zabbix -R /data/zabbix-4.4.3/script
[root@MySQL-Slave ~]# chmod 755 /data/zabbix-4.4.3/script/monitor_success_rate.py 
[root@MySQL-Slave ~]# ll /data/zabbix-4.4.3/script/
total 4
-rwxr-xr-x 1 zabbix zabbix 1325 Jan 3 10:14 monitor_success_rate.py

3、配置Zabbix Agent参数

[root@MySQL-Slave ~]# vi /data/zabbix-4.4.3/etc/zabbix_agentd.conf.d/monitor_success_rate.conf
UnsafeUserParameters=1
UserParameter=custom.success.rate[*],/usr/local/Python-3.6.6/bin/python3 /data/zabbix-4.4.3/script/monitor_success_rate.py $1

#注意
#如果Zabbix Agent需要以root身份运行的脚本的话,需要做如下修改,让Zabbix Agent以root身份运行,默认是zaabix身份运行
[root@MySQL-Slave ~]# vi /data/zabbix-4.4.3/etc/zabbix_agentd.conf
    259 ### Option: AllowRoot
    260 #       Allow the agent to run as 'root'. If disabled and the agent is started by 'root', the agent
    261 #       will try to switch to the user specified by the User configuration option instead.
    262 #       Has no effect if started under a regular user.
    263 #       0 - do not allow
    264 #       1 - allow
    265 #
    266 # Mandatory: no
    267 # Default:
    268 AllowRoot=1

4、配置完成,重启Zabbix Agent服务

[root@MySQL-Slave ~]# /etc/init.d/zabbix_agentd restart

5、到Zabbix服务端调用监控项

[root@filestore-v2 ~]# /data/application/zabbix-4.4.3/bin/zabbix_get -s 192.168.10.103 -p 10050 -k "custom.success.rate[wxxxxxx]"
94.918435

6、自定义脚本监控配置成功

7、配置触发器,这里不再介绍

02-09 21:52