1

Azure で Diagnostics を使用しているときに、何らかの理由でエラーが発生します。私の(WCF)WebRoleのコードは次のとおりです。

public override bool OnStart()
    {
        // To enable the AzureLocalStorageTraceListner, uncomment relevent section in the web.config  
        DiagnosticMonitorConfiguration diagnosticConfig = DiagnosticMonitor.GetDefaultInitialConfiguration();
        diagnosticConfig.Directories.ScheduledTransferPeriod = TimeSpan.FromMinutes(1);
        diagnosticConfig.Directories.DataSources.Add(AzureLocalStorageTraceListener.GetLogDirectory());
        diagnosticConfig.Directories.BufferQuotaInMB = 256;

        // Start diagnostics
        DiagnosticMonitor.Start("Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString", diagnosticConfig);

        // Write trace line
        Trace.WriteLine("CUSTUM TRACE MESSAGE");

        // Start instance
        return base.OnStart();
    }

私の Web.config ファイルは次のようになります。

<?xml version="1.0"?>
<configuration>
  <configSections>
  </configSections>
  <system.diagnostics>     
    <sharedListeners>
      <add name="AzureLocalStorage" type="WCFServiceWebRole1.AzureLocalStorageTraceListener, WCFServiceWebRole1"/>
    </sharedListeners>
    <sources>
      <source name="System.ServiceModel" switchValue="Verbose, ActivityTracing">
        <listeners>
          <add name="AzureLocalStorage"/>
        </listeners>
      </source>
      <source name="System.ServiceModel.MessageLogging" switchValue="Verbose">
        <listeners>
          <add name="AzureLocalStorage"/>
        </listeners>
      </source>
    </sources>
    <trace autoflush="true">
      <listeners>
        <add type="Microsoft.WindowsAzure.Diagnostics.DiagnosticMonitorTraceListener, Microsoft.WindowsAzure.Diagnostics, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
          name="AzureDiagnostics">
          <filter type="" />
        </add>
      </listeners>
    </trace>
  </system.diagnostics> 
  <system.web>
    <compilation debug="true" targetFramework="4.0" />
  </system.web>
  <system.serviceModel>
    <behaviors>
      <serviceBehaviors>
        <behavior>
          <!-- To avoid disclosing metadata information, set the value below to false and remove the metadata endpoint above before deployment -->
          <serviceMetadata httpGetEnabled="true"/>
          <!-- To receive exception details in faults for debugging purposes, set the value below to true.  Set to false before deployment to avoid disclosing exception information -->
          <serviceDebug includeExceptionDetailInFaults="false"/>
        </behavior>
      </serviceBehaviors>
    </behaviors>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
  </system.serviceModel>
  <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
  </system.webServer>
</configuration>

Compute Emulator に次のエラーが表示されます。

[MonAgentHost] Output: Monitoring Agent Started
[Diagnostics]: Starting configuration channel polling
[MonAgentHost] Error: MA EVENT: 2012-06-06T10:01:20.111Z
[MonAgentHost] Error:     2
[MonAgentHost] Error:     6396
[MonAgentHost] Error:     6624
[MonAgentHost] Error:     NetTransport
[MonAgentHost] Error:     0
[MonAgentHost] Error:     x:\btsdx\215\services\monitoring\shared\nettransport\src\xblobconnection.cpp
[MonAgentHost] Error:     XBlobConnection::PutBytesXBlob
[MonAgentHost] Error:     1621
[MonAgentHost] Error:     ffffffff80050023
[MonAgentHost] Error:     0
[MonAgentHost] Error:     
[MonAgentHost] Error:     Failed to send bytes to XContainer wad-tracefiles

このエラーが数回繰り返されます。"wad-tracefiles" コンテナーは、次のコードによって AzureLocalStorageTraceListener クラスに追加されます。

public static DirectoryConfiguration GetLogDirectory()
    {
        DirectoryConfiguration directory = new DirectoryConfiguration();
        directory.Container = "wad-tracefiles";
        directory.DirectoryQuotaInMB = 10;
        directory.Path = RoleEnvironment.GetLocalResource("WCFServiceWebRole1.svclog").RootPath;
        return directory;
    }

このシナリオでトレース メッセージの書き込みが失敗するのはなぜですか? Azure Storage Explorer で自分のストレージを調べると、WADLogsTable ではなく、WADDirectoriesTable だけが表示されます。「wad-tracefiles」ブロブは作成されますが、それは私のコードからトレース メッセージを見つけるべき場所ではありません。

誰か、何か考えはありますか?どんな助けでも大歓迎です!

4

2 に答える 2

0

お返事ありがとうございます!私が使用しているプロジェクトは、トレース メッセージが 1 つしかない非常に単純な WebRole であるため、コードを削除することはできません。

私はあなたの提案を試しましたが、あなたは正しいです。次のコードでエラーメッセージが表示されなくなりました。

public override bool OnStart()
    {
        setDiagnostics();

        Trace.WriteLine("CUSTUM TRACE MESSAGE");

        // Start instance
        return base.OnStart();
    }

    private void setDiagnostics()
    {
        // Get diagnostics connectionstring
        string wadConnectionString = "Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString";
        CloudStorageAccount cloudStorageAccount = CloudStorageAccount.Parse(RoleEnvironment.GetConfigurationSettingValue(wadConnectionString));

        // Get the diagnostics configuration of the deployment and its role instances that are currently running
        DeploymentDiagnosticManager deploymentDiagnosticManager = new DeploymentDiagnosticManager(cloudStorageAccount, RoleEnvironment.DeploymentId);
        RoleInstanceDiagnosticManager roleInstanceDiagnosticManager = cloudStorageAccount.CreateRoleInstanceDiagnosticManager(
            RoleEnvironment.DeploymentId,
            RoleEnvironment.CurrentRoleInstance.Role.Name,
            RoleEnvironment.CurrentRoleInstance.Id);

        // Load diagnostics configuration
        DiagnosticMonitorConfiguration diagConfig = roleInstanceDiagnosticManager.GetCurrentConfiguration();

        // Get the default value if there is no config yet
        if (diagConfig == null)
            diagConfig = DiagnosticMonitor.GetDefaultInitialConfiguration();

        // Enable EventLogs
        diagConfig.WindowsEventLog.DataSources.Add("Application!*");
        diagConfig.WindowsEventLog.ScheduledTransferPeriod = TimeSpan.FromMinutes(1D);
        diagConfig.WindowsEventLog.BufferQuotaInMB = 128;

        // Failed Request Logs
        diagConfig.Directories.DataSources.Add(AzureLocalStorageTraceListener.GetLogDirectory());
        diagConfig.Directories.ScheduledTransferPeriod = TimeSpan.FromMinutes(1D);
        diagConfig.Directories.BufferQuotaInMB = 128;

        // Crash Dumps
        CrashDumps.EnableCollection(true);

        // Set new configuration
        roleInstanceDiagnosticManager.SetCurrentConfiguration(diagConfig);

        // Start the DiagnosticMonitor
        DiagnosticMonitor.Start(wadConnectionString, diagConfig);
    }

Azure Storage Explorer に存在するテーブルを調べると、"WADDirectoriesTable" と "WADWindowsEventLogsTable" しか表示されません。トレース メッセージは "WADLogsTable" に入るべきですよね? そのため、Compute Emulator に Trace メッセージが表示されますが、ストレージには表示されません...理由はありますか?

于 2012-06-07T06:45:09.600 に答える