采用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 TRYEXEC sp_executesql @sql;
END TRY
BEGIN CATCHSET @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
测试验证数据采集正常