- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在一个 ASP.NET 网站上工作,该网站在某些请求上会运行一个非常冗长的缓存过程。我想知道如果在代码处理方式仍在运行时达到执行超时到底会发生什么。
我特别想知道如果代码在 try/finally block 的 try 中,finally 是否仍会运行?
此外,我不确定我是否希望缓存终止,即使它持续那么长时间是否有产生新线程等的方法,我可以绕过这个执行超时?我认为立即返回给用户并说“正在构建缓存”而不是让他们超时会更好。我最近开始使用一些锁定代码来确保一次只构建一个缓存,但我正在考虑扩展它以使其不同步。
我并没有像我一样真正玩过创建线程,所以不确定它们究竟是如何工作的,尤其是在与 ASP.NET 交互方面。例如,如果启动它的父线程终止,这会对衍生线程产生任何影响吗?
我知道这里有很多不同的问题,如果认为最好,我可以将它们分开,但它们似乎都放在一起......不过我会尝试总结这些问题:
很抱歉问了一些菜鸟问题,我从来没有真正玩过线程,它们仍然让我有点害怕(我的大脑说它们很难)。我可能可以测试很多这些问题的答案,但我对我的测试没有足够的信心。 :)
编辑添加:
回应资本G:
我遇到的问题是 ASp.NET 执行超时当前设置为 1 小时,我认为这对于其中一些进程来说并不总是足够长。我已经把一些东西和锁放在一起,以防止不止一个人触发这些漫长的过程,我担心锁可能不会被释放(我猜如果 finally block 不总是运行可能会发生)。
您对在 ASP.NET 中不运行长进程的评论是我考虑将它们移动到其他线程而不是阻塞请求线程的原因,但我不知道这是否仍然算作在 ASP.NET 体系结构中运行你说不好。
代码实际上不是我的,所以我不允许(并且不确定我是否 100% 足够理解它)将它重新编写成一个服务,尽管那肯定是它最好的地方。
在这种情况下,使用 BackgroundWorker 进程处理可能需要一个小时的事情是否可行(关于 ASP.NET 中长时间运行的进程的评论)。然后我会让请求返回一个“缓存正在构建”页面,直到它完成,然后返回正常服务……这有点像噩梦,但这是我的工作,所以我必须找到一种方法来改进它。 :)
最佳答案
有趣的问题,刚刚测试过,不,它不能保证执行 finally block 中的代码,如果线程被中止,它可能会在处理过程中的任何时候停止。您可以设计一些完整性检查和其他机制来处理特殊的清理例程等,但这也与您的线程处理有很大关系。
不一定,这取决于您如何实现线程。如果您自己使用线程,那么您很容易遇到父线程被终止而其子线程仍在处理的情况,您通常希望在父线程中进行一些清理以结束子线程。有些对象也可能为您做很多这样的事情,所以很难说是哪种方式。至少永远不要假设这一点。
不,不一定,至少不要假设这又与您的设计有关,以及您是自己进行线程化还是使用一些更高级别的线程化对象/模式。无论如何,我永远不会假设这一点。
我不建议在 ASP.NET 架构中长时间运行进程,除非它在典型的超时范围内,如果是 10-20 秒没问题,但如果是几分钟,则不,原因是 ASP.NET 中的资源使用这对用户来说非常糟糕。话虽这么说,您可以执行异步操作,将工作交给服务器,然后在处理完成后返回给用户,(这对于那些 10-20 秒以上的进程非常有用),可以给用户一点动画或以其他方式让他们的浏览器全部卡住那么长时间,等待服务器上发生的任何事情发生。
如果它是一个长时间运行的进程,需要超过 30-60 秒以上的时间,除非由于进程的性质而绝对必须在 ASP.NET 中完成,我建议将其移动到 Windows 服务并安排它在需要时以某种方式发生。
注意:线程可能很复杂,并不是说它很难,而是你必须非常清楚自己在做什么,这需要对线程是什么以及它们如何工作有深刻的理解,我不是专家,但我也不是全新的,我会告诉你,在大多数情况下,你不需要进入线程领域,即使你看起来像,但是如果你必须,我会建议调查BackgroundWorker 对象,因为它们为了进行批处理等目的而被简化(老实说,对于许多确实需要线程的情况,这通常是一个非常简单的解决方案)。
http://msdn.microsoft.com/en-us/library/system.componentmodel.backgroundworker.aspx
关于c# - 查看当 c#/ASP.NET 线程终止时会发生什么以及如何解决问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3501120/
一、前言: Python如何使用OS模块调用cmd 在os模块中提供了两种调用 cmd 的方法,os.popen() 和 os.system() os.system(cmd) 是在执行command命
我对双链表进行了简化。我的双链表是一个以头和尾为节点的结构。 有一个函数可以创建列表并返回它。在同一函数中,我执行尾节点和头节点之间的链接。问题是,当我返回列表(因此转到函数之外)时,所有链接都消失了
我有这个信息。 let params2: [String: AnyObject] = [ "app_token": myapptoken, "member_access_token":
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 年前。 Improve
我正在尝试发出解析为特定 IP 的 cURL 请求。从我读过的所有内容来看,这在我看来在语法上是正确的,但我仍然看到“无法解决主机错误”。有人能指出我正确的方向吗?我看到了各种错误: curl —-r
我正在尝试使用 curl 在 jira 服务器中获取数据。我试过这个命令 curl -u username:password -X GET -H "Content-Type: applicat
因此,下面的代码有时会起作用,有时它会添加&符号(到复制缓冲区),我试图从文本字符串中删除它。 代码的要点是将字符串从正确位置复制到与号之前。但是,在随机情况下,它仍然会添加 & 符号。 Privat
p = Int('p') q = Int('q') s = Solver() s.add(1<=p<=9, 1<=q<=19, 5<(3*p-4*q)<10) s.check() print s.mo
我在这里阅读了分配问题的解决方案:http://www.topcoder.com/tc?module=Static&d1=tutorials&d2=hungarianAlgorithm 我了解 O(n
控制台中显示警告: the id param was not provided. 文档提到将使用当前路由: current is the current Route by default (most
我正在尝试使用hector-core作为grails Maven构建中的依赖项。 me.prettyprint hector-core 1.0-3 bundle 我收到一个错误 [
我正在尝试使用 JavaScript 变得更好,并且我在破坏页面方面做得非常好:))))) 我正在尝试使用 Firebug 进行调试,但一开始有点困惑。它的哪个选项卡用于调试 JavaScript?我
我正在使用最新的 Angular + Firebase 并尝试设置登录授权系统。我有包含登录+注册链接的 home.html,转到 login.html 并添加凭据工作正常(提交时记录正确的 UID)
我有一个 iPad 应用,现在需要将其转换为通用应用。我已将目标设置为 Universal,现在它也可以部署到 iPhone,但是,我有一个主要问题:即使我已经创建了我的 main分别查看两种设备类型
我在 CSS 中使用媒体查询来根据 IE11 和 Chrome 的屏幕分辨率缩放我的网页。当我运行 this webpage在我的 2 个不同屏幕上的 chrome(顺便说一句,我用它来确定我的最小宽
我正在解决nodeschool练习“Juggling Async”,我是这样解决的 var http=require("http"); var urls=process.argv.slice(2,pr
我试图相对神秘地要求一个文件,发生了以下情况 这很好,它指向 /Users/marcos/Desktop/Taper/lib/utils.js myPath = "/Users/marcos/Desk
我正在尝试解决一个项目,但遇到了问题。 • 您的程序应该显示一个菜单,允许用户执行以下操作以下操作(注:使用GUI): 添加新客户 删除客户 修改客户信息//此选项必须显示子菜单: --------1
我需要 x 图标来删除输入字段值1. 当用户键入任何内容时,将显示“x”图标 如果输入框中没有可用的值,x 将被隐藏 当输入框中的值可用并且焦点移出输入框时,我们需要隐藏 x 图标并聚焦,我们需要再次
我正在使用 ajs(1.4.7) 和 angular-ui-router(0.2.15) 开发一个简单的 AJS 应用程序。 经历了this文章并选择了路由解析技术。 这是我遇到的错误 错误:[$in
我是一名优秀的程序员,十分优秀!