在我的一个asp.net站点中,提供了A,B两个功能,这两个功能都是比较耗Web服务器资源(主要是cpu)的,并且需要半分钟到一分钟才能完成功能。如果有一个用户正在使用A,B功能之一,w3wp的cpu占用率大概在50%左右;如果有两个或两个以上用户同时使用A,B两个功能之一,Web服务器就会变得不堪重负,cpu占用率将近100%,网站几乎无法对其他的请求进行任何响应,基本上所有页面都会报超时错误。
我曾想过把这两个功能从立即执行的执行方式改为建立一个任务队列,在凌晨的时候通过一个专门的服务来依次执行任务队列里的任务。但想想又实在不甘心,因为这大大降低了这两个功能的易用性。况且,在一个站点中出现这种很耗资源的操作的情况应该是比较常见的,应该通过其他更高级的任务或者线程管理来解决。我目前能想到的可能的解决途径包括:
(1)对网站的线程池进行配置,限定每一个线程最大的cpu占用率。(如何设置?是只能设置一个固定的百分比还是能根据当前服务器cpu的占用率设置一个动态值?)
(2)把A,B这两个功能串行化,也就是创建一个队列,如果某用户要执行A,B功能之一,看看队列是否为空,不为空则加入队列末尾。这种办法明显降低了程序的并发性,但比较容易操作,也比凌晨执行服务的方法实时性好得多。
应该还有更好的解决方案,请各位多多帮忙了。