#region License Information /* HeuristicLab * Copyright (C) 2002-2012 Heuristic and Evolutionary Algorithms Laboratory (HEAL) * * This file is part of HeuristicLab. * * HeuristicLab is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * HeuristicLab is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with HeuristicLab. If not, see . */ #endregion using System; using System.Threading; using HeuristicLab.Services.Hive.DataAccess; using System.Diagnostics; namespace HeuristicLab.Services.Hive { public class HiveJanitor { private bool stop; private AutoResetEvent waitHandle; private DataAccess.ITransactionManager trans { get { return ServiceLocator.Instance.TransactionManager; } } private IEventManager eventManager { get { return ServiceLocator.Instance.EventManager; } } private IHiveDao dao { get { return ServiceLocator.Instance.HiveDao; } } public HiveJanitor() { stop = false; waitHandle = new AutoResetEvent(true); } public void StopJanitor() { stop = true; waitHandle.Set(); } public void Run() { while (!stop) { try { LogFactory.GetLogger(typeof(HiveJanitor).Namespace).Log("HiveJanitor: starting cleanup"); Trace.WriteLine("HiveJanitor: starting cleanup"); bool cleanup = false; DateTime lastCleanup = DateTime.MinValue; trans.UseTransaction(() => { lastCleanup = dao.GetLastCleanup(); }, true); if (DateTime.Now - lastCleanup > HeuristicLab.Services.Hive.Properties.Settings.Default.CleanupInterval) { trans.UseTransaction(() => { dao.SetLastCleanup(DateTime.Now); }, true); dao.SetLastCleanup(DateTime.Now); cleanup = true; } if (cleanup) { eventManager.Cleanup(); } LogFactory.GetLogger(typeof(HiveJanitor).Namespace).Log("HiveJanitor: cleanup finished"); Trace.WriteLine("HiveJanitor: cleanup finished"); } catch (Exception e) { LogFactory.GetLogger(typeof(HiveJanitor).Namespace).Log(string.Format("HiveJanitor: The following exception occured: {0}", e.ToString())); Trace.WriteLine(string.Format("HiveJanitor: The following exception occured: {0}", e.ToString())); } waitHandle.WaitOne(HeuristicLab.Services.Hive.Properties.Settings.Default.CleanupInterval); } waitHandle.Close(); } } }