4

我有一个长期运行的 SSIS 包,其中包含许多数据流任务(有关 SSIS 的更多信息,请参阅此问题)。在这些任务之间,我想将实时状态更新发送到在 IIS 7.0 中托管的面向 Intranet 的 ASP.NET MVC 4 应用程序中运行的 SignalR 集线器,以便用户可以查看进度。

从 SSIS 向 SignalR 集线器客户端发送状态更新消息的最佳方式是什么?

以下 SSIS 任务似乎能够将消息传递到外部系统:

  • SSIS 消息队列任务:在服务器上使用 MSMQ 私有队列起初听起来很容易,除了 MSMQ 有点过时、未维护且缺乏文档。也没有明显的方法可以与现有的启用 SignalR 的 Web 应用程序集成。有一篇关于连接到 MSMQ 的自托管 SignalR 集线器的文章,但是这种方法在 ASP.NET MVC 应用程序中是否可行?

  • SSIS 执行 SQL 任务:我已经从 SSIS 执行此操作(更新作业表中的 status_id),因此困难的部分是检测这些更改并通过 SignalR 集线器路由它们。SignalR已经可以使用 SQL Server 进行横向扩展,但此技术假定所有消息一开始都是通过SignalR 集线器进入的,此处并非如此。其他人谈论使用SqlDependency,但这是否可以让 ASP.NET 应用程序查看数据库表并收到所有更新的通知?

  • 使用 SSIS 脚本任务发送 HTTP 请求 (C#):经过反思,这似乎是最直接的路线,但有一些注意事项。我正在构建的 Web 应用程序经过 NTLM 身份验证,因此我需要将 System.Net.WebRequest 与身份验证一起使用,这在 SSIS 中可能有问题,也可能没有问题。

关于#3 的更新:SSIS 包正在 SQL Server 中运行。如果我使用System.Net.CredentialCache.DefaultNetworkCredentials. 因此,如果可以使用备用 NTLM 凭据(即不是从运行包的帐户派生),WebRequest 似乎只能在这种情况下工作。该站点不接受基本的 HTTP 身份验证。

更新 2:看起来 System.Net.NetworkCredentials 可以用任意域/用户/密码实例化并应用于 WebRequest。我尚未在 SSIS 任务中的生产环境中对此进行测试。这个问题仍然悬而未决,因为维护许多相同的 SSIS 脚本任务(或开发可重用的 SSIS 任务)相当麻烦。可能有一个更简单、更快或更易于维护的解决方案。

关于赏金的更新 3:400 代表的赏金将授予提出可行策略并至少提供一些基本细节的最佳答案。

4

3 回答 3

2

SSIS 消息队列任务

如果使用它,则必须将消息发布到队列(MSMQ 是具有文件数据库的服务)。消息可以是任何你想要的。然后,您必须编写一个 Windows 服务来轮询 MSMQ 队列中的消息(或注册到 MSMQ 事件)并使用 C# signalr 客户端将消息传输到 Web 客户端。

+: MSMQ itself is reliable, MSMQ can post the message to other MSMQ
+: MSMQ will retain messages if they can not be delivered
-: All servers having MSMQ must be in the same Active Directory domain.
-: The service is not easy to write, if an error occurs in it all messages in the queue can be blocked (if the problematic message stays at the top of the queue)
-: It is not so easy to setup the security of MSMQ
-: There is no tool to recover the file db if it crashes.

我的想法是,如果您的消息通过本地网络/vpn 长距离传输,并且您的消息必须到达并且永远不会丢失,那么您使用 MSMQ。

在您的情况下,如果消息未到达,则不是灾难性的...

执行 SQL 任务

不要更新自己的信号器数据库。这不是一个可靠且长期有效的解决方案。

也不要在 SQL 表上使用监视功能(它称为服务代理)。根据我的经验,它不可靠,它不断断开连接,无缘无故拒绝(重新)连接,而且 C# api 很糟糕。事实上,您只收到一个更改通知,然后您自己找出更改并重新注册以进行更改。

您可以做的是使用包括信号器客户端的 CLR 存储过程。但是,如果您有 sql 2008R2 或更低版本,则它必须是 .NET 2.0,这是 signalr 不支持的(我很确定,但应该验证)。参考:http ://technet.microsoft.com/en-us/library/ms131103.aspx

使用 SSIS 脚本任务发送 HTTP 请求(使用 NTLM)

HTTP 请求是最好的方法。您可以将代码放在 CLR 存储过程中,这样它就可以重用,并使用执行 sql 任务。参考:http ://technet.microsoft.com/en-us/library/ms190790(v=sql.105).aspx

于 2013-09-10T18:25:11.153 回答
1

我会简单地采用 #3 并在本地安装ntlmaps(启用自定义 NTML 凭据的代理服务器)并在配置文件中正确定义网络设置。

于 2013-09-10T12:58:31.817 回答
1

我认为您可以为此目的使用 SQL Server 服务代理。

此外,似乎有人取得了类似的成就: Pushing data from SQL Server to Web Application with SignalR

于 2013-09-04T18:04:02.327 回答