采用bat结合zabbix监控sqlserver数据库表的信息

采用bat结合zabbix监控sqlserver数据库表的信息,当表插入某个特定的值的时候就发出告警。

监控需求:数据库存在某个表,该表不是一个固定的表名字,而且根据当前的日期生成表,比如tab20240501,tab20240502,需要查询当天的表数据

数据采集脚本,首先定一个sql脚本,查询指定的数据

SET NOCOUNT ON;

DECLARE @todayDate NVARCHAR(10) = FORMAT(GETDATE(), 'yyyyMMdd');
DECLARE @tableName NVARCHAR(50) = N'alerm' + @todayDate;
DECLARE @sql NVARCHAR(MAX);
DECLARE @resultMessage NVARCHAR(MAX);

SET @sql = N'
SELECT 
    STRING_AGG(CONCAT(aname, '','', CONVERT(varchar(100), atime, 20)), ''|'') WITHIN GROUP (ORDER BY aname) AS MergedFields
FROM ' + 'TESTDB.DBO.' + QUOTENAME(@tableName)
+ '
where atime>=DATEADD(MINUTE, - 30, GETDATE()) '

BEGIN TRY
    EXEC sp_executesql @sql;
END TRY
BEGIN CATCH
    SET @resultMessage = N'Table ' + QUOTENAME(@tableName) + N' does not exist';
    SELECT @resultMessage AS ErrorMessage;
END CATCH;

再定义一个bat脚本执行sql文件
@echo off
sqlcmd -S 127.0.0.1 -i D:\tempfile\getdata2.sql -s “,” -W -h-1 -k1
pause

测试验证数据采集正常

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值