10

我有一些 .Net WCF 服务,对于这些服务,我已配置 app.config 文件以将发送和接收的消息记录在 .svclog 文件中,该文件可由“服务跟踪查看器工具”(SvcTraceViewer.exe) 读取。这个工具很好地呈现日志文件,清楚地显示正在处理的 SOAP 消息。

我必须使用 System.Diagnostics.XmlWriterTraceListener 侦听器来正确格式化 .svclog 文件以供服务跟踪查看器工具处理。

我遇到的问题是 .svclog 文件变得太大,并且由于响应时间慢,服务跟踪查看器工具变得无法使用。

服务跟踪查看器工具确实提供了一种工具,允许在文件大小 > 40MB 时打开部分日志文件,但这仍然太慢。app.config 文件中似乎没有工具可以将 .svclog 配置为每天或当文件达到特定大小时自动创建一个新文件。

有一个名为 Microsoft.VisualBasic.Logging.FileLogTraceListener 的文本日志侦听器,它支持 logfilecreationschedule="Daily" 属性,该属性每天滚动日志文件,但是从该侦听器生成的日志文件很难让操作支持人员用作日志条目没有很好地呈现,并且大型 xml 文档造成了混乱。

这方面的最佳实践是什么,看起来我可能不得不编写一个自定义 WCF 日志扩展,这似乎有点矫枉过正,只是为了处理内置 System.Diagnostics.XmlWriterTraceListener 日志侦听器中缺少日志文件滚动功能/附加器。

我还尝试了一个脚本来停止我的应用程序并重命名日志文件,但这似乎不可能,因为在 Windows 上,handle.exe 和 openfile 实用程序无法关闭通过网络共享打开的文件,因此我无法重命名/ 如果有人通过网络共享浏览旧日志文件,则移动它。不久将发布一个单独的问题。

谢谢,马特。

4

2 回答 2

9

您可以自己开发,也可以使用已经存在的专用XmlWriterTraceListener或使用循环跟踪日志机制。

有一个专门的实现,XmlWriterTraceListener它在 Codeproject 上执行滚动日志跟踪:

http://www.codeproject.com/Articles/30956/A-Rolling-XmlWriterTraceListener

使用循环跟踪,您有两个文件,每个文件最多可以存储所需跟踪日志数据总数的一半。侦听器创建一个文件并写入该文件,直到达到数据大小一半的限制,此时它切换到第二个文件。当侦听器达到第二个文件的限制时 - 它会用新的跟踪覆盖第一个文件。

http://msdn.microsoft.com/en-us/library/aa395205.aspx

于 2012-06-09T23:46:34.853 回答
0

我拼凑了一个 Powershell 脚本,该脚本修改了 SVC 的 web.config 中的日志文件的名称,然后创建了一个 TaskScheduler 作业来每小时运行一次脚本。

$a = (((get-date).ToUniversalTime()).ToString("yyyyMMddThhmmssZ"))
$myLogFile = "c:\temp\$a.svclog";
$webConfig = 'C:\inetpub\wwwroot\mySVCapi\Web.config'
Function updateConfig($config) 
{ 
$doc = (Get-Content $config) -as [Xml]
$activeConnection =$doc.configuration.'system.diagnostics'.sources.source.listeners.add#.initializeData
$activeConnection.SetAttribute("initializeData", $myLogFile);
$doc.Save($config)
} 
updateConfig($webConfig)

该脚本假定您的 web.config 中有类似的内容:

  <system.diagnostics>
<sources>
  <source name="System.ServiceModel.MessageLogging">
    <listeners>
      <add name="messages" type="System.Diagnostics.XmlWriterTraceListener" initializeData="c:\temp\myDefaultLogFile.svclog" />
    </listeners>
  </source>
</sources>

在 Task sched 中,Action-Start A Program 中,放入Powershell.exeProgram/script 框,然后 -ExecutionPolicy ByPass c:\yourfolder\amendWebConfig.ps1在 Add arguments 框中添加。

任务运行,然后将 web.config 的 initializeData 文件更新为,例如

    <listeners>
      <add name="messages" type="System.Diagnostics.XmlWriterTraceListener" initializeData="c:\temp\20180606T020646Z.svclog" />
    </listeners>
于 2018-06-06T14:30:49.650 回答