12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using Aitex.Core.Util;
- using log4net.Core;
- using System.Diagnostics;
- namespace Aitex.Core.RT.Log
- {
- public class LogManager : ICommonLog
- {
- PeriodicJob _loggingJob;
- FixSizeQueue<LogItem> _logQueue;
- LogWriter _writer;
- public LogManager()
- {
- }
- public void Initialize()
- {
- _logQueue = new FixSizeQueue<LogItem>(1000);
- _loggingJob = new PeriodicJob(300, this.PeriodicRun, "Save Log Job", true);
- _writer = new LogWriter();
- LOG.InnerLogger = this;
- }
- public void Terminate()
- {
- try
- {
- if (_loggingJob != null)
- {
- _loggingJob.Stop();
- _loggingJob = null;
- }
- }
- catch (Exception ex)
- {
- System.Diagnostics.Trace.WriteLine(ex.Message);
- }
- }
- public void Info(string message, bool isTraceOn, string stackFile)
- {
- CacheLog(message, Level.Info, null, isTraceOn, stackFile);
- }
- public void Warning(string message, string stackFile)
- {
- CacheLog(message, Level.Warn, null, true, stackFile);
- }
- public void Error(string message, string stackFile)
- {
- CacheLog(message, Level.Error, null, true, stackFile);
- }
- public void Warning(string message, Exception ex, string stackFile)
- {
- CacheLog(message, Level.Warn, ex, true, stackFile);
- }
- public void Error(string message, Exception ex, string stackFile)
- {
- CacheLog(message, Level.Error, ex, true, stackFile);
- }
- bool PeriodicRun()
- {
- LogItem item;
- while (_logQueue.TryDequeue(out item))
- {
-
- string log = _writer.Write(item);
- }
- return true;
- }
- void CacheLog(string message, Level level, Exception exception, bool isTraceOn, string stackFile)
- {
- //if (isTraceOn)
- //{
- // System.Diagnostics.Trace.WriteLine(message + (exception == null ? "" : exception.Message));
- //}
- _logQueue.Enqueue(new LogItem(message, new StackTrace(true).GetFrame(5), level, exception, stackFile));
- }
- }
- }
|