1

我正在使用以下 web.config 为我的 WCF 服务启用跟踪。虽然文件是在本地主机上正常创建的,但在部署我的服务的服务器上没有创建文件。

<system.diagnostics>
    <sources>
      <source name="System.ServiceModel"
              switchValue="Information, ActivityTracing"
              propagateActivity="true">
        <listeners>
          <add name="traceListener"
              type="System.Diagnostics.XmlWriterTraceListener"
              initializeData= "c:\log\Traces.svclog" />
        </listeners>
      </source>
    </sources>
  </system.diagnostics>

我已授予 ASP.NET 帐户指定文件夹的写入权限。我究竟做错了什么?

4

3 回答 3

3

这听起来很像权限问题。

您说您授予了 ASP.NET 帐户的写入权限,但您的服务可能不在此帐户下运行。

例如,在 IIS 7 Windows 2008 中,默认帐户称为ApplicationPoolIdentity. 在 IIS 6 Windows 2003 下,此默认帐户称为NetworkService. 但在这两种情况下,当然可以在 IIS 控制面板中进行修改。

因此,当您说ASP.NET 帐户以及您授予哪个帐户权限时,您的意思并不十分清楚。此外,除了授予写入权限之外,您可能还需要授予修改权限,以便进程可以在文件不存在时创建文件。否则,您需要先手动创建它。如果您不确定在哪个帐户下运行您的 Web 服务,您可以使用SysInternals Process Explorer工具来找出答案。

此外,IIRC 日志可能不会立即刷新到日志文件中。它会在内存中保存一段时间并每隔一段时间刷新一次。重新启动应用程序池可确保内容立即刷新到文件中。

于 2012-06-15T12:04:38.787 回答
0

上面的答案非常好,值得研究。我还要补充一点,您应该确保在配置文件中启用了消息日志记录。像这样的东西(只是一个例子):

<system.serviceModel>
    <diagnostics>
        <messageLogging
            logEntireMessage="true"
            logMalformedMessages="false"
            logMessagesAtServiceLevel="true"
            logMessagesAtTransportLevel="false"
            maxMessagesToLog="3000"
            maxSizeOfMessageToLog="2000"/>
    </diagnostics>
</system.serviceModel>

我不确定这是否能解决您的问题,但它在过去帮助我解决了类似的问题。希望能帮助到你。

于 2012-06-15T12:07:51.830 回答
0

您是否在 Web 服务器上安装了跟踪功能?

于 2012-06-15T12:03:42.540 回答