控制台托管的WCF服务无法跟踪。

4
我编写了一个简单的服务合同(IServiceObject),然后实现了它(ServiceObject)。我将其托管在一个包含在控制台应用程序中的ServiceHost对象中。在其中一个OperationContract方法内,我调用Trace.WriteLine(...)和Console.WriteLine(...)。在控制台应用程序中,在我打开ServiceHost之前和之后,我调用Trace.WriteLine(...)和Console.WriteLine(...)。
Trace设置为自动刷新,并且具有两个侦听器(TextWriterTraceListener和ConsoleTraceListener)。当控制台应用程序启动时,所有Trace和Console WriteLine()调用都将写入各自的日志。因此,Trace调用将写入我的文本文件和我的控制台,而Console调用将写入我的控制台。
当我的客户端应用程序(另一个应用程序)调用OperationContract方法时,只有其中的Console.WriteLine(...)调用会显示在控制台屏幕上。Trace.WriteLine(...)调用不会写入到控制台屏幕或文本文件中。
当我在OperationContract方法内查询Trace状态(使用Console.WriteLine(...)将其输出到控制台屏幕上)时,我被告知Trace中有2个侦听器(Text和Console),并且自动刷新已打开。
有人知道为什么我的对Trace.WriteLine(...)的调用无法从OperationContract方法内写入任何侦听器吗?我需要在ServiceObject类上装饰一些特定的属性吗?我可能遗漏了某些设置吗?对我来说,追踪已正确配置,因为除了在我的OperationContract方法内部以外的所有地方都可以工作...
这似乎是一个问题,即只包含我的OperationContract及其实现的共享库:
IServiceObject.cs
using System;
using System.Collections.Generic;
using System.Text;
using System.ServiceModel;
using System.Diagnostics;

namespace SuccessEHS.Dev.Shared
{
    [ServiceContract]
    public interface IServiceObject
    {
        [OperationContract]
        bool Test(string text);
    }
}

ServiceObject.cs

using System;
using System.Collections.Generic;
using System.Text;
using System.Diagnostics;
using System.ServiceModel;

namespace SuccessEHS.Dev.Shared
{
    public class ServiceObject : IServiceObject
    {
        public bool Test(string text)
        {
            Console.Write("Testing 1");
            Trace.Write("..2");
            Console.Write("..3");
            Trace.Write("..4");
            Console.WriteLine("..5");

            Console.WriteLine("CW: {0}", text);
            Trace.WriteLine(string.Format("TW: {0}", text));

            return true;
        }
    }
}

Shared.csproj(我怀疑是罪魁祸首,但不确定原因):

<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <PropertyGroup>
    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
    <ProductVersion>8.0.30703</ProductVersion>
    <SchemaVersion>2.0</SchemaVersion>
    <ProjectGuid>{23F9A333-9CC8-43FA-8A01-06BEA8B9D0E6}</ProjectGuid>
    <OutputType>Library</OutputType>
    <AppDesignerFolder>Properties</AppDesignerFolder>
    <RootNamespace>Shared</RootNamespace>
    <AssemblyName>SharedTest</AssemblyName>
    <TargetFrameworkVersion>v3.5</TargetFrameworkVersion>
    <FileAlignment>512</FileAlignment>
    <TargetFrameworkProfile />
  </PropertyGroup>
  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
    <DebugSymbols>true</DebugSymbols>
    <DebugType>full</DebugType>
    <Optimize>false</Optimize>
    <OutputPath>bin\Debug\</OutputPath>
    <DefineConstants>DEBUG;TRACE</DefineConstants>
    <ErrorReport>prompt</ErrorReport>
    <WarningLevel>4</WarningLevel>
    <PlatformTarget>x86</PlatformTarget>
  </PropertyGroup>
  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
    <DebugType>pdbonly</DebugType>
    <Optimize>true</Optimize>
    <OutputPath>bin\Release\</OutputPath>
    <DefineConstants>TRACE</DefineConstants>
    <ErrorReport>prompt</ErrorReport>
    <WarningLevel>4</WarningLevel>
  </PropertyGroup>
  <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'">
    <DebugSymbols>true</DebugSymbols>
    <OutputPath>bin\x86\Debug\</OutputPath>
    <DefineConstants>DEBUG;TRACE</DefineConstants>
    <DebugType>full</DebugType>
    <PlatformTarget>x86</PlatformTarget>
    <CodeAnalysisLogFile>bin\Debug\Shared.dll.CodeAnalysisLog.xml</CodeAnalysisLogFile>
    <CodeAnalysisUseTypeNameInSuppression>true</CodeAnalysisUseTypeNameInSuppression>
    <CodeAnalysisModuleSuppressionsFile>GlobalSuppressions.cs</CodeAnalysisModuleSuppressionsFile>
    <ErrorReport>prompt</ErrorReport>
    <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
    <CodeAnalysisRuleSetDirectories>;C:\Program Files (x86)\Microsoft Visual Studio 10.0\Team Tools\Static Analysis Tools\\Rule Sets</CodeAnalysisRuleSetDirectories>
    <CodeAnalysisIgnoreBuiltInRuleSets>true</CodeAnalysisIgnoreBuiltInRuleSets>
    <CodeAnalysisRuleDirectories>;C:\Program Files (x86)\Microsoft Visual Studio 10.0\Team Tools\Static Analysis Tools\FxCop\\Rules</CodeAnalysisRuleDirectories>
    <CodeAnalysisIgnoreBuiltInRules>true</CodeAnalysisIgnoreBuiltInRules>
  </PropertyGroup>
  <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'">
    <OutputPath>bin\x86\Release\</OutputPath>
    <DefineConstants>TRACE</DefineConstants>
    <Optimize>true</Optimize>
    <DebugType>pdbonly</DebugType>
    <PlatformTarget>x86</PlatformTarget>
    <CodeAnalysisLogFile>bin\Release\Shared.dll.CodeAnalysisLog.xml</CodeAnalysisLogFile>
    <CodeAnalysisUseTypeNameInSuppression>true</CodeAnalysisUseTypeNameInSuppression>
    <CodeAnalysisModuleSuppressionsFile>GlobalSuppressions.cs</CodeAnalysisModuleSuppressionsFile>
    <ErrorReport>prompt</ErrorReport>
    <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
    <CodeAnalysisRuleSetDirectories>;C:\Program Files (x86)\Microsoft Visual Studio 10.0\Team Tools\Static Analysis Tools\\Rule Sets</CodeAnalysisRuleSetDirectories>
    <CodeAnalysisIgnoreBuiltInRuleSets>true</CodeAnalysisIgnoreBuiltInRuleSets>
    <CodeAnalysisRuleDirectories>;C:\Program Files (x86)\Microsoft Visual Studio 10.0\Team Tools\Static Analysis Tools\FxCop\\Rules</CodeAnalysisRuleDirectories>
    <CodeAnalysisIgnoreBuiltInRules>true</CodeAnalysisIgnoreBuiltInRules>
  </PropertyGroup>
  <ItemGroup>
    <Reference Include="System" />
    <Reference Include="System.Data" />
    <Reference Include="System.ServiceModel" />
    <Reference Include="System.Xml" />
  </ItemGroup>
  <ItemGroup>
    <Compile Include="Class1.cs" />
    <Compile Include="Properties\AssemblyInfo.cs" />
  </ItemGroup>
  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
  <!-- To modify your build process, add your task inside one of the targets below and uncomment it. 
       Other similar extension points exist, see Microsoft.Common.targets.
  <Target Name="BeforeBuild">
  </Target>
  <Target Name="AfterBuild">
  </Target>
  -->
</Project>

我建立了一个新的服务器控制台应用程序来托管一个新的共享库和一个新的客户端控制台应用程序来连接它,并没有出现任何问题。但是,当我将此项目作为共享库导入(如上所述),ServiceObject.cs 中发现的跟踪功能无法正常工作。有什么新的想法吗?


你能提供一个最小的代码示例来重现这个问题吗?我猜这可能不是必需的(因为我想这可能是某种追踪配置问题),但对于阅读和回答问题的人来说可能会有帮助。 - Merlyn Morgan-Graham
我打算开始一个新项目,它有最少的代码来查看是否可以跟踪。一旦我写好了,我会发布它。 - Schrader
2个回答

1

本文介绍了如何启用并且配置WCF的跟踪侦听器/源。这里有多个部分,如果您错过其中的一些部分,我预计跟踪将无法正常工作。


我不想启用WCF源代码。我读了这篇文章,但它没有提供任何解决此问题的线索。我只想知道为什么在托管对象中使用.net Trace类时,即使自对象被托管以来配置没有更改,它也不会产生任何跟踪输出。而且,托管对象的程序可以进行跟踪,即使对象正在被托管。对于设置WCF源代码不错的文章。 (注意:当我启用WCF源代码时,我得到所有的跟踪,但仍然无法跟踪Trace.WriteLine(...))。 - Schrader
@Schrader:糟糕啊,等你发布代码到 OP 后我会去看看的。 - Merlyn Morgan-Graham
是的,这让我感到困惑,但我太顽固了,不会放弃,除非得到某种答案,即使答案最终是向微软提交错误报告 :P - Schrader

0

当我查看来自WCF侦听器的数据时,我使用ServiceTraceViewer。然而,跟踪侦听器中没有任何内容显示在那里,甚至包括在托管应用程序中工作的跟踪。虽然我不认为它会显示在那里,因为那些侦听器没有链接到System.Diagnostics.Trace侦听器。 - Schrader

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接