美文网首页
sqlserver使用触发器执行cmd命令,更新logstash

sqlserver使用触发器执行cmd命令,更新logstash

作者: 程政_2533 | 来源:发表于2019-10-29 00:00 被阅读0次

    先说一下生产环境,使用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命令,所以只能执行一条串起来的命令行,所以用& 符号来拼接。

    相关文章

      网友评论

          本文标题:sqlserver使用触发器执行cmd命令,更新logstash

          本文链接:https://www.haomeiwen.com/subject/nxwivctx.html