public static class LogHelper { private static readonly Queue<Dictionary<string, string>> Que = new Queue<Dictionary<string, string>>(); private static readonly Object Object = new Object(); private static EnumLogLevel LogType { get; set; } static LogHelper() { ThreadPool.QueueUserWorkItem(s => { while (true) { if (Que.Count <= 0) { Thread.Sleep(5000); continue; } lock (Object) { if (Que.Count <= 0) { Thread.Sleep(5000); continue; } var currentDirectory = AppDomain.CurrentDomain.BaseDirectory; var path = string.Format("{0}Logs\\", currentDirectory); if (!Directory.Exists(path)) { Directory.CreateDirectory(path); } var fileName = Path.Combine(path, DateTime.Now.ToString("yyyy-MM-dd") + ".log"); using (var fs = new FileStream(fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite)) { using (var sw = new StreamWriter(fs)) { sw.BaseStream.Seek(0, SeekOrigin.End); var col = Que.Dequeue(); foreach (KeyValuePair<string, string> m in col) { sw.WriteLine(m.Key + ":{0}", m.Value); } sw.Flush(); sw.Dispose(); sw.Close(); } } } } }); } public static string WriteLog(this string str, EnumLogLevel type = EnumLogLevel.Info) { var logLevel = ConfigurationManager.AppSettings["LogLevel"]; var level = string.IsNullOrWhiteSpace(logLevel) ? EnumLogLevel.Info.ToString() : logLevel; if ((int)type < (int)Enum.Parse(typeof(EnumLogLevel), level)) { return string.Empty; } lock (Object) { LogType = type; var st = new StackTrace(new StackFrame(1, true)); StackFrame sf = st.GetFrame(0); var dic = new Dictionary<string, string> { {"發(fā)生時間", DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss:ffff dddd")}, {"日志級別", LogType.ToString()}, {"日志消息", str}, {"當(dāng)前方法", sf.GetMethod().Name}, {"發(fā)生位置", st.ToString()} }; Que.Enqueue(dic); } return str; } } /// <summary> /// All: 表示最低的日志等級。 /// Debug: 這個等級表示用于調(diào)試程序的正常的事件信息; /// Info: 默認(rèn)的等級 /// Warn: 表示可能對系統(tǒng)有損害的情況; /// Error: 表示較嚴(yán)重的錯誤等級,但是程序可以繼續(xù)運行的信息; /// Fatal: 表示非常嚴(yán)重的錯誤等級,記錄極有可能導(dǎo)致應(yīng)用程序終止運行的致命錯誤信息; /// Off: 表示最高的等級,如果一個logger的等級標(biāo)記為Off, 將不會記錄任何信息; /// </summary> public enum EnumLogLevel { All, Debug, Info, Warn, Error, Fatal, Off }
|
|