统计zabbix指定日期内的告警数量

问题描述:
知名企业A公司的运维人员小智,需要对zabbix发生的告警数量进行统计。
解决方案:
1、数据库查询方案,调整时间范围即可查询告警相应数据:

查询最近30天zabbix告警数据
SELECT
        a.hostid ,
        a.`host`,
        a.`name` AS hostnname,
        b.`name` AS groupname,
        FROM_UNIXTIME( e.clock ) AS eventtime,
        e.`name`,
        e.severity 
FROM
        hosts a
        JOIN hosts_groups c ON a.hostid = c.hostid
        JOIN hstgrp b ON b.groupid = c.groupid 
        AND b.NAME LIKE '%***%'
        JOIN items d ON a.hostid = d.hostid 
        AND d.flags <> 1 
        AND d.flags <> 2
        JOIN ( SELECT itemid, triggerid FROM functions GROUP BY itemid, triggerid ) f ON d.itemid = f.itemid
        JOIN events e ON f.triggerid = e.objectid 
        AND e.`value` = 1 
				AND e.clock in (select e.clock from events e where TIMESTAMPDIFF(day,from_unixtime(e.clock,'%Y-%m-%d'),current_date)<30)
        
ORDER BY e.clock

2、使用zabbix api获取

import requests
import json
from datetime import datetime

# Zabbix API相关信息
zabbix_url = 'http://your-zabbix-server/zabbix/api_jsonrpc.php'
zabbix_username = 'your_username'
zabbix_password = 'your_password'

# 登录Zabbix并获取认证令牌
def zabbix_login():
    data = {
        'jsonrpc': '2.0',
        'method': 'user.login',
        'params': {
            'user': zabbix_username,
            'password': zabbix_password,
        },
        'id': 1,
    }

    response = requests.post(zabbix_url, json=data, headers={'Content-Type': 'application/json'})
    result = response.json()

    if 'result' in result:
        return result['result']
    else:
        raise Exception("Zabbix login failed")

# 获取指定日期范围内的告警数量
def get_alert_count(start_date, end_date):
    token = zabbix_login()

    data = {
        'jsonrpc': '2.0',
        'method': 'alert.get',
        'params': {
            'output': 'extend',
            'time_from': datetime.strptime(start_date, '%Y-%m-%d').timestamp(),
            'time_till': datetime.strptime(end_date, '%Y-%m-%d').timestamp(),
            'selectAcknowledges': 'extend',
            'sortfield': 'clock',
            'sortorder': 'DESC',
        },
        'auth': token,
        'id': 2,
    }

    response = requests.post(zabbix_url, json=data, headers={'Content-Type': 'application/json'})
    #查询数据在此
    result = response.json()

    if 'result' in result:
        return len(result['result'])
    else:
        raise Exception("Failed to retrieve alert count")

# 指定日期范围
start_date = '2024-01-01'
end_date = '2024-01-10'

# 获取告警数量
alert_count = get_alert_count(start_date, end_date)
print(f"Alert count from {start_date} to {end_date}: {alert_count}")

请确保替换代码中的以下值:

‘http://your-zabbix-server/zabbix/api_jsonrpc.php’:Zabbix服务器的API URL。
‘your_username’:用于登录Zabbix的用户名。
‘your_password’:用于登录Zabbix的密码。
此代码登录到Zabbix,获取认证令牌,然后使用alert.get方法获取指定日期范围内的告警数量。注意,Zabbix的API调用可能会受到Zabbix服务器配置和权限的影响,确保用户具有足够的权限执行相应的API调用。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要使用 Zabbix 实现 QQ 邮箱告警,你需要按照以下步骤进行配置: 1. 确保 Zabbix 服务器和代理已正确安装和配置。 2. 登录 Zabbix Web 界面,并转到 "Administration"(管理)-> "Media types"(媒体类型)。 3. 点击 "Create media type"(创建媒体类型)。 4. 在 "Type"(类型)字段中选择 "Email"(电子邮件)。 5. 在 "SMTP server"(SMTP 服务器)字段中输入 QQ 邮箱的 SMTP 服务器地址(例如:smtp.qq.com)。 6. 在 "SMTP helo" 字段中输入 Zabbix 服务器的主机名或 IP 地址。 7. 在 "SMTP email"(发件人电子邮件)字段中输入 QQ 邮箱的完整电子邮件地址。 8. 在 "SMTP security"(SMTP 安全性)字段中选择适当的安全选项。如果使用 SSL/TLS,请选择适当的加密方式。 9. 输入你的 QQ 邮箱的登录凭据,包括 "SMTP username"(SMTP 用户名)和 "SMTP password"(SMTP 密码)。 10. 确定所有设置都正确无误后,点击 "Save"(保存)。 接下来,你需要为 Zabbix 用户配置 QQ 邮箱告警: 1. 转到 "Administration"(管理)-> "Users"(用户)。 2. 选择要配置 QQ 邮箱告警的用户,或创建新用户。 3. 在 "Media"(媒体)选项卡中,点击 "Add"(添加)。 4. 在 "Type"(类型)字段中选择刚才创建的 QQ 邮箱媒体类型。 5. 在 "Send to"(接收者)字段中输入 QQ 邮箱地址。 6. 确保 "Enabled"(已启用)复选框被选中。 7. 保存更改。 最后,你需要在 Zabbix 中配置告警动作以触发 QQ 邮箱告警: 1. 转到 "Configuration"(配置)-> "Actions"(动作)。 2. 选择要配置 QQ 邮箱告警的动作,或创建新动作。 3. 在 "Operations"(操作)选项卡中,点击 "New"(新建)。 4. 在 "Send to Users"(发送给用户)字段中选择配置了 QQ 邮箱告警的用户。 5. 配置其他告警操作,如邮件主题、邮件内容等。 6. 保存更改。 完成上述步骤后,当触发了相关的告警条件时,Zabbix 将通过 QQ 邮箱发送告警通知给指定的用户。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酱江奖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值