1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2025-01-21 11:02:01 +02:00
Sonarr/NzbDrone/PriorityMonitor.cs

53 lines
1.6 KiB
C#
Raw Normal View History

2013-02-28 16:50:50 -08:00
using System.Linq;
using System;
2011-10-06 23:36:04 -07:00
using System.Diagnostics;
using System.Threading;
2011-10-06 23:36:04 -07:00
using NLog;
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
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()
{
_processPriorityCheckTimer = new Timer(EnsurePriority);
_processPriorityCheckTimer.Change(TimeSpan.FromSeconds(15), TimeSpan.FromMinutes(30));
2011-10-06 23:36:04 -07:00
}
public virtual void EnsurePriority(object sender)
2011-10-06 23:36:04 -07:00
{
try
2011-10-06 23:36:04 -07: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);
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
}
}
}
}