温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何使用SQL Server代理运行CmdExec命令

发布时间:2021-12-30 16:20:54 来源:亿速云 阅读:361 作者:小新 栏目:数据库

这篇文章将为大家详细讲解有关如何使用SQL Server代理运行CmdExec命令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

需求:调用网服务器(SMS SQL Server)上的短信发送接口(是一个存储过程)来发送(Stage SQL Server)上的数据内容到本Team 成员的手机上。这两台服务器,本地在拨VPN后可以访问。要求以本地的SQL Server做跳转,同时调用这两台服务器的数据接口。

  实现方法与步骤(在本地的SQL Server环境):

  1、创建一个SQL Server Job

  2、创建一个调用 操作系统(CmdExec)命令的Job步骤,调用命令以完成自动拨VPN的功能。

  代码如:

rasdial idc_name user_name user_password


  3、创建链接服务器SMS SQL Server和Stage SQL Server。

  4、创建一个读取Stage SQL Server上需要发送的数据内容,并调度SMS SQL Server的短信发送接口,完成短信发送的Job步骤(T-SQL)。

  5、创建一个CmdExec的Job步骤,调用命令完成自动断开VPN的功能。

  代码如:

rasdial idc_name /disconnect


  6、设置这三个步骤的先后顺序(2,4,5)。并设置调度频率为每天早上9点。

  该过程中可能涉及到两个问题,如下:

  1、分别调用两个服务器上的存储过程,可能需要打开分布式事务。简要步骤如下:

  运行dcomcnfg命令,组件服务,计算机,我的电脑,属性,MSDTC,安全配置

  选中“网络DTC访问”

  在客户端管理中选中“允许远程客户端”“允许远程管理”

  在事务管理通讯中选“允许入站”“允许出站”“不要求进行验证”

  保证DTC登陆账户为:NT AuthorityNetworkService

  2、执行CmdExec步骤的默认帐号是SQL Server代理的启动帐号,一般是 NT AUTHORITYNetworkService,该帐号不是sysadmin组,

  不具备执行该命令的权限。所以可能需要修改代理的启动帐号为有权限的帐号。

关于“如何使用SQL Server代理运行CmdExec命令”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI