0

我计划实现错误日志记录,编写类似于的内容:

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);
        }

    }

我的问题是:由于它是一个网站,我将同时拥有多个用户。在那种情况下,如果多个用户同时遇到异常并尝试写入同一个文件,它会再次给我一个异常对吗?在这种情况下,如何为同时用户正确实现错误日志记录?或者这会奏效吗?

提前致谢。

4

2 回答 2

3

我建议您使用已建立的日志记录框架,例如NLoglog4net。我过去在许多项目中都使用过 log4net,它完美地处理了这种情况。

编辑:

正如进一步的评论,以及处理来自多个线程的日志消息,log4net 还允许您管理日志文件的增长量,并通过RollingFileAppender提供内置的滚动日志机制。

于 2013-01-27T10:28:07.450 回答
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();
    }   
}
于 2013-01-27T10:43:23.610 回答