Trace.WriteLine () Сообщения сохраняются только в OnStart () для Azure WorkerRole - PullRequest
4 голосов
/ 11 августа 2011

Я занимаюсь разработкой Azure WorkerRole ().В консоли Compute Emulator я вижу все сообщения Trace.WriteLine (), но только те сообщения, которые сгенерированы в OnStart (), по-видимому, сохраняются в хранилище.

My ServiceConfiguration.Local.csfg имеет:

<Role name="MyWorkerRole">
  <Instances count="1" />
  <ConfigurationSettings>
    <Setting name="Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString" value="UseDevelopmentStorage=true" />
  </ConfigurationSettings>
</Role>

Мой WorkerRole.cs имеет:

public override void Run() {
    Trace.WriteLine("Called from Run(), where does this trace go???", "Information");

    // ... SNIP ...
}
public override bool OnStart() {
    // Set the maximum number of concurrent connections 
    ServicePointManager.DefaultConnectionLimit = 12;

    DiagnosticMonitorConfiguration dmc = DiagnosticMonitor.GetDefaultInitialConfiguration();
    dmc.Logs.ScheduledTransferPeriod = TimeSpan.FromMinutes(1);
    dmc.Logs.ScheduledTransferLogLevelFilter = LogLevel.Verbose;
    DiagnosticMonitor.Start("DiagnosticsConnectionString", dmc);

    Trace.WriteLine("This trace appears in WADLogsTable", "Information");

    return base.OnStart();
}

1 Ответ

3 голосов
/ 11 августа 2011

Это выглядит правильно - интересно, почему ты ничего не видишь. Интересно, если Start игнорирует ваши изменения конфигурации как-то. Вот код, который я использовал для передачи журналов трассировки (я знаю, что это работает):

    private static void EnableDiagnostics(int transferTime)
    {
        string wadConnectionString = "Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString";
        CloudStorageAccount storageAccount = CloudStorageAccount.Parse(RoleEnvironment.GetConfigurationSettingValue(wadConnectionString));

        RoleInstanceDiagnosticManager roleInstanceDiagnosticManager = storageAccount.CreateRoleInstanceDiagnosticManager(RoleEnvironment.DeploymentId, RoleEnvironment.CurrentRoleInstance.Role.Name, RoleEnvironment.CurrentRoleInstance.Id);
        DiagnosticMonitorConfiguration config = roleInstanceDiagnosticManager.GetCurrentConfiguration();

        if (config == null)
        {
            config = DiagnosticMonitor.GetDefaultInitialConfiguration();
        }

        config.Logs.ScheduledTransferPeriod = TimeSpan.FromMinutes(transferTime);
        config.Logs.ScheduledTransferLogLevelFilter = LogLevel.Undefined;

        CrashDumps.EnableCollection(true);

        roleInstanceDiagnosticManager.SetCurrentConfiguration(config);
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...