我打算实现类似于this的错误日志记录:
public static void WriteError(string errorMessage)
{
try
{
string path = "~/Error/" + DateTime.Today.ToString("dd-mm-yy") + ".txt";
if (!File.Exists(System.Web.HttpContext.Current.Server.MapPath(path)))
{
File.Create(System.Web.HttpContext.Current.Server.MapPath(path)).Close();
}
using (StreamWriter w = File.AppendText(System.Web.HttpContext.Current.Server.MapPath(path)))
{
w.WriteLine("\r\nLog Entry : ");
w.WriteLine("{0}", DateTime.Now.ToString(CultureInfo.InvariantCulture));
string err = "Error in: " + System.Web.HttpContext.Current.Request.Url.ToString() +
". Error Message:" + errorMessage;
w.WriteLine(err);
w.WriteLine("__________________________");
w.Flush();
w.Close();
}
}
catch (Exception ex)
{
WriteError(ex.Message);
}
}
我的问题是:由于它是一个网站,我将同时拥有多个用户。在这种情况下,如果多个用户同时遇到异常并尝试写入同一个文件,它会再次给我一个例外吗?在这种情况下,如何为同时用户正确实现错误日志记录?或者这会有用吗?
提前致谢。
答案 0 :(得分:3)
我建议您使用已建立的日志记录框架,例如NLog或log4net。我过去在许多项目中使用过log4net,它完美地处理了这个场景。
编辑:
作为进一步的评论,以及处理来自多个线程的日志消息,log4net还允许您管理日志文件的增长程度,并通过RollingFileAppender提供内置的滚动日志机制。
答案 1 :(得分:1)
除了使用NLog或其他日志库之外,锁定此案例的方式还有互斥锁。我建议mutex
,而不是lock()
因为可以捕获可能引发错误的所有池/线程。
在MSDN上有关于mutex
和示例的详细信息:
http://msdn.microsoft.com/en-us/library/system.threading.mutex.aspx
一个简单的例子
public static void WriteError(string errorMessage)
{
var mut = new Mutex(true, "LogMutexName");
try
{
// Wait until it is safe to enter.
mut.WaitOne();
// here you open write close your file
}
finally
{
// Release the Mutex.
mut.ReleaseMutex();
}
}