我有一个ASP.NET MVC应用程序,允许用户存储视频和照片等媒体.
该应用程序还允许用户删除存储在服务器中的那些媒体.为此,我想实现“两步”过程,其中首先(当选择要删除媒体时),数据库中的媒体条目将获得一个时间戳,指示必须在一段时间内删除该条目(例如一个月);如果在该时间内未删除该时间戳,则应该存在每天执行的调度方法,并检查媒体条目是否具有足够大的时间戳以便删除.
我的问题是关于调度程序:
我已经知道有一些像FluentScheduler或Quartz.NET这样的框架来实现这种工作.由于应用程序是在IIS中部署的Web应用程序,我害怕不使用正确的方式,框架或方法来实现它.由于IIS可以随时关闭我的应用程序,并且由于调度的方法将执行写入DB和IO文件系统以删除db条目和物理文件,因此对我来说,该方法完全执行或不执行all,保持db与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);
}
});
}
最佳答案 如果您要安排任务,至少您希望至少在
HostingEnvironment.QueueBackgroundWorkItem的上下文中执行此操作.这将在ASP.NET运行时注册您的工作.虽然有警告.当ASP.NET因任何原因进行回收时,它将通知后台工作(通过设置CancellationToken),然后它将等待一段指定的时间(我认为30秒)才能完成工作.如果后台工作没有在该时间范围内完成,则工作将会消失.
FluentScheduler和Quartz是很好的框架,但是如果你能避免它,你应该避免在ASP.NET应用程序的上下文中安排工作(出于上述原因).您可以创建一个使用这些框架来安排应用程序之外的作业/重复任务的服务.
但是,更强大的选择是使用像Hangfire这样的技术/框架,它与某些可靠的存储(如SQL Server,Redis或MSMQ)配合使用.
Hangfire is an open-source framework that helps you to create, process
and manage your background jobs, i.e. operations you don’t want to put
in your request processing pipeline.