- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个长期运行的 SSIS 包,其中包含许多数据流任务(有关 SSIS 的详细信息,请参阅 this question)。在这些任务之间,我想将实时状态更新发送到在 IIS 7.0 中托管的面向 Intranet 的 ASP.NET MVC 4 应用程序中运行的 SignalR 中心,以便用户可以查看进度。
从 SSIS 向 SignalR 中心客户端发送状态更新消息的最佳方式是什么?
以下 SSIS 任务似乎能够将消息传递到外部系统:
SSIS 消息队列任务:在服务器上使用 MSMQ 专用队列一开始听起来很简单,只是 MSMQ 有点过时、缺乏维护且缺乏文档。也没有一种明显的方法可以与现有的支持 SignalR 的 Web 应用程序集成。有一个write-up about a self-hosted SignalR hub with connections to MSMQ ,但是这种方法可以在 ASP.NET MVC 应用程序中实现吗?
SSIS 执行 SQL 任务:我已经从 SSIS 执行此操作(更新作业表中的 status_id),因此困难的部分是检测这些更改并通过SignalR 集线器。 SignalR already can use SQL Server for scaling out ,但此技术假设所有消息一开始都是通过 SignalR 集线器传入的,但这里的情况并非如此。其他人谈论使用 SqlDependency ,但这是否可以使 ASP.NET 应用程序监视数据库表并收到所有更新通知?
使用 SSIS 脚本任务发送 HTTP 请求 (C#):经过反射(reflection),这似乎是最直接的途径,但有一些注意事项。我正在构建的 Web 应用程序经过 NTLM 身份验证,因此我需要使用 System.Net.WebRequest 进行身份验证,这在 SSIS 中可能会出现问题,也可能不会出现问题。
关于 #3 的更新:SSIS 包正在 SQL Server 中运行。如果我使用 System.Net.CredentialCache.DefaultNetworkCredentials 向站点进行身份验证,则其运行的 Windows 帐户将无法授权。因此,似乎 WebRequest 只能在这种情况下工作,如果可以使用备用 NTLM 凭据(即不是从运行程序包的帐户派生)。该网站不接受基本的 HTTP 身份验证。
更新 2:看起来 System.Net.NetworkCredentials 可以使用任意域/用户/密码实例化并应用于 WebRequest。我还没有在 SSIS 任务的生产中对此进行测试。这个问题仍然悬而未决,因为维护许多相同的 SSIS 脚本任务(或开发可重用的 SSIS 任务)相当麻烦。可能有更简单、更快或更易于维护的解决方案。
关于赏金奖励的更新 3:400 名代表的赏金将授予提出可行策略并至少提供一些基本细节的最佳答案。
最佳答案
SSIS Message Queue Task
如果您使用它,则必须将消息发布到队列(MSMQ 是具有文件数据库的服务)。该消息可以是您想要的任何内容。然后,您必须编写一个 Windows 服务来轮询 MSMQ 队列中的消息(或注册到 MSMQ 事件),并使用 C# 信号器客户端将消息传输到 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。
就您而言,如果消息未到达,这并不是灾难性的......
Execute SQL Task
不要自行更新信号数据库。这不是一个可靠且长期存在的解决方案。
也不要在 SQL 表上使用监视功能(称为 Service Broker)。根据我的经验,它不可靠,它不断断开连接,无缘无故拒绝(重新)连接,而且 C# api 很糟糕。事实上,您只会收到一项更改通知,然后您必须自己查找更改并重新注册更改。
您可以做的是使用包含信号客户端的 CLR 存储过程。但如果你有 sql 2008R2 或更低版本,它必须是 .NET 2.0,signalr 不支持它(我很确定,但应该验证)。引用:http://technet.microsoft.com/en-us/library/ms131103.aspx
Use the SSIS Script task to send an HTTP request (using NTLM)
HTTP 请求是最好的方法。您可以将代码放入 CLR 存储过程中,这样它将可重用,并使用执行 sql 任务。引用:http://technet.microsoft.com/en-us/library/ms190790(v=sql.105).aspx
关于asp.net - 将消息从 SSIS (2012) 包推送到 ASP.NET Web 应用程序中的 SignalR 中心 - 最好的方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18523401/
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!