登录C#网站时出错

时间:2013-01-27 10:25:46

标签: c# asp.net .net logging error-handling

我打算实现类似于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);
        }

    }

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

提前致谢。

2 个答案:

答案 0 :(得分:3)

我建议您使用已建立的日志记录框架,例如NLoglog4net。我过去在许多项目中使用过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();
    }   
}