在C#.NET Web应用程序

时间:2016-07-18 15:04:54

标签: c# asp.net web scheduled-tasks

我有一个ASP.NET MVC应用程序,可以让用户存储视频和照片等媒体。

该应用程序还允许用户删除存储在服务器中的媒体。为此,我想实施一个"两个步骤"首先(当选择删除媒体时),数据库中的媒体条目将获得一个时间戳,该时间戳指示必须在某个时间(例如一个月)删除该条目;如果在该时间内没有删除该时间戳,则应该有一个每天执行的调度方法,并检查媒体条目是否具有足够大的时间戳以便删除。

我的问题是关于调度程序: 我已经知道有一些框架如FluentScheduler或Quartz.NET来实现这类工作。由于应用程序是在IIS中部署的Web应用程序,因此我不敢使用正确的方法,框架或方法来实现它。由于IIS可以随时关闭我的应用程序,并且由于调度的方法将执行写入DB和IO文件系统以删除db条目和物理文件,因此对我来说,该方法完全执行或不执行all,保持数据库与hd。

中存储的文件一致

我的第一个赌注是FluentScheduler,但我需要知道使用这样的框架是否是最好的解决方案。

我知道StackOverflow不欢迎这类问题。这不是一个意见问题,我只想阅读解决方案并选择最符合我要求的解决方案。

以下是调度方法中的某些伪代码:

using(ViewMediaDBUnitOfWork uw = new ViewMediaDBUnitOfWork())
        {
            var today = DateTime.Now.Date;

            List<Media> mediaToDelete = uw.MediaRepository.Get(m => (m.ToDelete - today).value.Days > 30);
            mediaToDelete.ForEach(m =>
            {
                try
                {
                    //Deletes from DB
                    uw.MediaRepository.Delete(m);
                    //Deletes the file
                    File.Delete(m.Path);
                    //If everything is ok, savechanges
                    uw.MediaRepository.SaveChanges();
                }
                catch(Exception e)
                {
                    LogManager.GetCurrentClassLogger().Error("Error deleting. " + m.Path, e);
                }                    
            });
        }

2 个答案:

答案 0 :(得分:2)

如果您要安排任务,至少您希望至少在HostingEnvironment.QueueBackgroundWorkItem的上下文中执行此任务。这将使用ASP.NET运行时注册您的工作。虽然有警告。当ASP.NET因任何原因进行回收时,它将通知后台工作(通过设置CancellationToken),然后它将等待一段指定的时间(我认为30秒)才能完成工作。如果后台工作没有在该时间范围内完成,那么工作就会消失。

FluentScheduler和Quartz是很好的框架,但是如果可以避免,可以避免在ASP.NET应用程序的上下文中安排工作(出于上述原因)。您可以创建一个使用这些框架来安排应用程序之外的作业/重复任务的服务。

然而,更强大的选择是使用像Hangfire这样的技术/框架,它与某些可靠的存储(如SQL Server,Redis或MSMQ)配合使用。

  

Hangfire是一个开源框架,可以帮助您创建,处理   并管理你的后台工作,即。你不想放的操作   在您的请求处理管道中

答案 1 :(得分:0)

听起来你最好创建一个单独的服务来处理时间戳记录的删除,而不是试图将它捆绑到你现有的应用程序中。

作为一个非常快速的解决方案,创建运行SQL查询的a Powershell script大约需要10分钟,删除TimeStamp&gt;中的数据。 x日期。

然后您可以schedule this script每天运行。它比希望IIS工作线程池线程仍在运行更可靠。

还有其他一些方法,例如SSIS,但可能比你需要的更复杂。