2013-02-28 16:50:50 -08:00
|
|
|
using System.Linq;
|
|
|
|
using System;
|
2011-10-06 23:36:04 -07:00
|
|
|
using System.Diagnostics;
|
2012-02-10 17:43:07 -08:00
|
|
|
using System.Threading;
|
2011-10-06 23:36:04 -07:00
|
|
|
using NLog;
|
2011-10-22 22:26:43 -07:00
|
|
|
using NzbDrone.Common;
|
2011-10-06 23:36:04 -07:00
|
|
|
|
2013-02-28 16:50:50 -08:00
|
|
|
namespace NzbDrone
|
2011-10-06 23:36:04 -07:00
|
|
|
{
|
2013-02-28 16:50:50 -08:00
|
|
|
public class PriorityMonitor
|
2011-10-06 23:36:04 -07:00
|
|
|
{
|
|
|
|
private readonly ProcessProvider _processProvider;
|
2013-02-28 16:50:50 -08:00
|
|
|
private readonly Logger _logger;
|
2011-10-06 23:36:04 -07:00
|
|
|
|
2012-02-10 17:43:07 -08:00
|
|
|
private Timer _processPriorityCheckTimer;
|
2011-10-06 23:36:04 -07:00
|
|
|
|
2013-02-28 16:50:50 -08:00
|
|
|
public PriorityMonitor(ProcessProvider processProvider, Logger logger)
|
2011-10-06 23:36:04 -07:00
|
|
|
{
|
|
|
|
_processProvider = processProvider;
|
2013-02-28 16:50:50 -08:00
|
|
|
_logger = logger;
|
2011-10-06 23:36:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public void Start()
|
|
|
|
{
|
2012-02-10 17:43:07 -08:00
|
|
|
_processPriorityCheckTimer = new Timer(EnsurePriority);
|
|
|
|
_processPriorityCheckTimer.Change(TimeSpan.FromSeconds(15), TimeSpan.FromMinutes(30));
|
2011-10-06 23:36:04 -07:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2012-02-10 17:43:07 -08:00
|
|
|
public virtual void EnsurePriority(object sender)
|
2011-10-06 23:36:04 -07:00
|
|
|
{
|
2012-03-02 11:58:31 -08:00
|
|
|
try
|
2011-10-06 23:36:04 -07:00
|
|
|
{
|
2012-03-02 11:58:31 -08:00
|
|
|
var currentProcess = _processProvider.GetCurrentProcess();
|
|
|
|
if (currentProcess.Priority != ProcessPriorityClass.Normal)
|
|
|
|
{
|
|
|
|
_processProvider.SetPriority(currentProcess.Id, ProcessPriorityClass.Normal);
|
|
|
|
}
|
2011-10-06 23:36:04 -07:00
|
|
|
|
2013-02-18 17:13:42 -08:00
|
|
|
var iisProcess = _processProvider.GetProcessById(_processProvider.GetCurrentProcess().Id);
|
2012-03-02 11:58:31 -08:00
|
|
|
if (iisProcess != null && iisProcess.Priority != ProcessPriorityClass.Normal &&
|
|
|
|
iisProcess.Priority != ProcessPriorityClass.AboveNormal)
|
|
|
|
{
|
|
|
|
_processProvider.SetPriority(iisProcess.Id, ProcessPriorityClass.Normal);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
2011-10-06 23:36:04 -07:00
|
|
|
{
|
2013-02-28 16:50:50 -08:00
|
|
|
_logger.WarnException("Unable to verify priority", e);
|
2011-10-06 23:36:04 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|