3

我是 .net 跟踪的新手。

我的应用程序中有近 10 到 15 个跟踪源,在共享侦听器列表中有一个文本文件侦听器和 sql 服务器侦听器。我的问题是如果我打电话

 traceSource.TraceInformation("Sample information")

然后调用线程将被阻塞,直到它被文本文件侦听器和 sql server 侦听器处理/跟踪。或者 TraceSource 内部包含任何日志队列,这样调用线程将立即被释放,日志将在后台线程中完成。

基本上我不希望调用线程被阻塞,直到它被所有跟踪侦听器记录。如果我想这样实现,那么我应该使用自定义侦听器吗?

4

1 回答 1

0

您的跟踪仅与您的侦听器一样多线程安全。如果许多线程试图通过跟踪写入同一个文件,可能会发生争用,如果当前日志文件已经打开,一些侦听器将写入另一个日志文件。我从写入控制台跟踪侦听器的经验中知道,有时文本会在两个线程尝试同时写入控制台时交错。这对我来说意味着 System.Diagnostics 框架代码中的任何内容都不会强制阻塞。

要测试慢速侦听器块,您可以通过实现自定义侦听器凭经验确定,我推荐这个基类,因此您实际上最多只需要重写两个方法来编写自定义侦听器。添加一个 Thread.Sleep(6000) 并查看是否所有线程都阻塞。

如果是这样,您可能需要考虑将跟踪调用放入某种即发即弃的调用中,可能是 Task.Run、Task.StartNew 或新的 Thread/Start。但是,我怀疑创建新线程的开销可能会使性能比阻塞几毫秒更差。这是一个相关的问题

于 2012-10-10T00:39:49.607 回答