4

我有一个存在很长时间(数小时到数月)的类的实例。它有一种将日志事件输出到文本文件的方法C:\mylog.txt。如下

public MyClass
{
    private static System.Diagnostics.TraceSource traceSource = new System.Diagnostics.TraceSource("My.Source");

    private static void MyMethod()
    {
        traceSource.TraceEvent(System.Diagnostics.TraceEventType.Information, 0, "MyMethod called.");
    }
}

C:\mylog.txt可能会变得很大,我想删除它。但是我可能无法删除文件,因为它被锁定了traceSource(通过终止进程我可以删除文件)。

如上所述,所有示例都将System.Diagnostics.TraceSource其实例声明为静态类成员。鉴于我的情况,是否可以通过以下方法对其进行初始化?

public MyClass
{
    private static void MyMethod()
    {
        var traceSource = new System.Diagnostics.TraceSource("My.Source");
        traceSource.TraceEvent(System.Diagnostics.TraceEventType.Information, 0, "MyMethod called.");
    }
}

或者是否有特定原因必须将其声明为静态?难道我做错了什么?文件锁定是预期/必需的行为吗?

4

1 回答 1

6

对于这个问题,您正在查看铁轨的错误一侧。TraceSource 不决定如何记录跟踪数据。这是由.NET 中的另一个类 TraceListener 完成的。两者之间的划分很重要,跟踪源只是跟踪信息的一个有趣来源,侦听器准确地确定如何过滤不太重要的信息以及如何记录它。

从您如何配置侦听器的问题中没有任何见解。使用 .config 文件是一种常用方法。

你需要一个不同类型的听众。一个非常简单的方法是在需要记录跟踪事件时打开日志文件,并在写入字符串后立即再次关闭它。这使您可以删除文件,尽管您仍然必须在正确的时间执行此操作。然而,这不是正确的方式,它是非常低效的。

一个常见的解决方案是“滚动附加程序”,一种将日志信息记录到文件中但确保它不会变得太大的侦听器。然后切换到另一个文件并删除非常旧的文件,这样你就不会得到太多的文件。不是您想自己编写的那种代码,它可以从库中轻松获得。您可以通过 Nuget 获得的那种。我推荐NLog,它基于流行的 Apache Log4Net 库,但更加以 .NET 为中心。 这个问题涵盖了它。

于 2015-03-30T10:38:01.030 回答