Я хочу добавить трассировку в мои задачи запуска. Я пытался включить DiagnosticsMonitorTraceListener в сценарии powershell, который запускается перед всеми фактическими задачами запуска. Код:
Add-Type -Path ./Microsoft.WindowsAzure.Diagnostics.dll
$listener = new-object -type Microsoft.WindowsAzure.Diagnostics.DiagnosticMonitorTraceListener
[System.Diagnostics.Trace]::Listeners.Add($listener)
$credentials = new-object -type Microsoft.WindowsAzure.StorageCredentialsAccountAndKey -argumentlist "ACCOUNT_NAME", "ACCOUNT_KEY"
$dmConfig = Microsoft.WindowsAzure.Diagnostics.DiagnosticMonitor]::GetDefaultInitialConfiguration();
$dmConfig.Logs.ScheduledTransferPeriod = [System.TimeSpan]::FromMinutes(1)
[Microsoft.WindowsAzure.Diagnostics.DiagnosticMonitor]::Start("Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString", $dmConfig)
Почему-то мои следы такие:
[System.Diagnostics.Trace]::TraceInformation("Starting startup tasks")
никогда не переносится в хранилище Azure. Скрипт запускается без проблем.
Я знаю, что есть способ заставить диагностическую инфраструктуру Azure копировать журналы, созданные задачами запуска, но насколько я понимаю, DiagnosticMonitor запускается только при запуске роли. Что, если задача запуска завершится неудачно и роль не запустится - журналы не сохранятся.
Пожалуйста, дайте мне знать, если я иду неправильным путем, чтобы решить это. Спасибо.