【问题标题】:Long Running Tasks - Best Practice - ASP.NET 4.0, C#长时间运行的任务 - 最佳实践 - ASP.NET 4.0,C#
【发布时间】:2013-04-16 11:37:11
【问题描述】:

处理需要很长时间执行的流程的推荐方法是什么?我不想简单地在服务器上运行它,因为页面会超时。

我浏览了网络并找到了多种方法 - AJAX、线程、Web 服务......(我没有经验)

处理这个问题的最佳实践方法是什么?

谢谢。

【问题讨论】:

    标签: c# asp.net ajax web-services


    【解决方案1】:

    如果您只是想执行一项长时间运行的任务,那么 Windows 服务非常适合。不,不是 Web 服务,而是老式的 Windows 服务。当有人上传 Excel 时,您的 Windows 服务可以使用 FileWatcher 监视目录,然后自动执行导入过程。这样,您就不会将进程限制为 ASP.NET 和 IIS Worker 进程,它们可以出于多种原因被回收。听起来您的应用程序确实需要在 IIS 之外。上传过程可以是一个简单的 Web 前端,用于将该文件放入您的 Windows 服务监控的目录中。

    【讨论】:

      【解决方案2】:

      一种透明且可靠的方法是将所需任务与处理队列一起实现为 WebService。因此,在客户端,您可以简单地向网络服务器发送请求,接收一些 id 作为回报,以便稍后检查结果。

      其他一切都取决于您尝试实现的丰富用户体验。您可以简单地让用户通过按下按钮不时刷新控件或整个页面。或者实现基于 ajax 的控件,它自己不时发送请求并检查结果。

      【讨论】:

      • 感谢您的回复。如前所述,我确实遇到了 Web 服务作为一种选择。我特别想知道这是否是最佳实践。一旦我知道它是,我会进一步研究它(我会使用新的 Web API 吗?)我的情况是用户将大型 excel 文件上传到服务器并将记录添加到数据库。
      【解决方案3】:

      根据您的要求,您可以设置一个 WebService(或者更准确地说,一个 WCF service,因为不推荐使用常规 XML WebServices),就像 pukipuki 提到的那样。

      如果长时间运行的过程很复杂(步骤很多、非常密集、可能会被转移到其他服务器)或需要稳健(作业可能会失败并需要重试等),您可能想要研究使用某种形式的消息队列来控制进出执行长时间运行过程的服务的流量。消息队列在某些情况下肯定是多余的,但它也是一个很好的框架,提供消息存储、持久性和流控制,因此您不必自己构建它。 Here 很好地概述了如何将 MSMQ 与 ASP.NET 一起使用(对不起,示例代码似乎是 VB 而不是 C#)。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2018-04-10
        • 2015-12-04
        • 1970-01-01
        • 2011-12-05
        • 2012-08-13
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多