先说一下生产环境,使用logstash采集sqlserver数据库中的数据,在es和kibana共同展示大数据效果。
现使用触发器来执行cmd命令来运行logstash -f xx.conf 来执行实时更新
使用了以下2个知识点:
1,触发器:当sqlserver更新/删除/插入数据时,触发器实时来执行语句;
2,vbs:windows系统下的可执行文件,可在后台执行cmd命令;
开启xp_cmdshell命令(可在sqlserver中执行cmd命令)代码:
EXEC sp_configure 'show advanced options',1
EXEC sp_configure 'xp_cmdshell',1
RECONFIGURE
触发器代码:
CREATE TRIGGER Update_table
ON tablename
AFTER INSERT,DELETE,UPDATE
AS
BEGIN
EXEC xp_cmdshell 'D: & \Elastic\logstash-7.2.0\autorun.vbs',no_output'
END
autorun.vbs代码:
Set ws = CreateObject("Wscript.Shell")
ws.run "cmd /c cd d: & cd D:\Elastic\logstash-7.2.0&bin\logstash -f config\sqlserver\logstash-sample.conf",vbhide
遇到的坑:
1,sqlserver 中的xp_cmdshell命令,默认是关闭的,要先设置开启。
2,触发器在xp_cmdshell命令直接执行cmd命令时,如果执行的命令耗时超过30秒(实际测试会更短),sqlserver会报超时错误,表修改的操作会回滚到初始状态,导致修改表数据失败,所以采用直接执行vbs文件的方式来操作,无论vbs执行的时间有多长,触发器执行耗时时间都会很短,不会再弹出超时错误。
3,cmd命令行执行非C盘目录下的文件时,会不报错误,一闪而过,命令不会执行;而在powershell命令中执行就没问题。例如:打开cmd命令,当前的路径是用户的路径:c:\user\home 直接执行 D:\test\test01.vbs 是一闪而过并没有执行的,应该先切换到D盘,再执行:
c:\user\home cd D: (或者不用CD 直接输入 D: 回车 同样切换盘符操作)
D: \test\test01.vbs
这样执行下来就没问题了
然而
sqlserver中的xp_cmdshell 命令并不支持多行cmd命令,所以只能执行一条串起来的命令行,所以用& 符号来拼接。