Exportar (0) Imprimir
Expandir Tudo

Alterar remotamente a configuração do monitor de diagnóstico

Atualizado: dezembro de 2013

Depois de ter implantado um serviço de nuvem, você poderá alterar remotamente a configuração do monitor de diagnóstico no código que está sendo executado em um aplicativo fora do Windows Azure usando a classe DeploymentDiagnosticManager. Nessa classe, você pode modificar os monitores de diagnóstico para uma ou mais instâncias de função. Você também pode alterar a configuração do monitor de diagnóstico para apenas para uma instância de função usando a classe RoleInstanceDiagnosticManager.

Alterar remotamente a configuração do monitor de diagnóstico

O exemplo a seguir atualiza remotamente a coleção de dois contadores de desempenho em um serviço de nuvem. Adicione uma referência de projeto à Microsoft.WindowsAzure.Diagnostics.dll, que está instalada no diretório %Arquivos de Programas%\Microsoft SDKs\Windows Azure.NET SDK\<número_da_versão>\ref\.

using Microsoft.WindowsAzure.Diagnostics; 
using Microsoft.WindowsAzure.Diagnostics.Management;

...

// Get the connection string. It's recommended that you store the connection string in your web.config or app.config file.
// Use the ConfigurationManager type to retrieve your storage connection string.  You can find the account name and key in
// the Windows Azure Management Portal (http://manage.windowsazure.com).
//string connectionString = "DefaultEndpointsProtocol=https;AccountName=<AccountName>;AccountKey=<AccountKey>";
string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["StorageConnectionString"].ConnectionString;

// The deployment ID and role name for your application can be obtained from the Windows Azure Management Portal (http://manage.windowsazure.com).  
// See your application dashboard under Cloud Services.
string deploymentID = "28267ed8caf3424eab3f0b01acdd7281";
string roleName = "WebRole1";

// Get the DeploymentDiagnosticManager object for your deployment.
DeploymentDiagnosticManager diagManager = new DeploymentDiagnosticManager(connectionString, deploymentID);

// Get the RoleInstanceDiagnosticManager objects for each instance of your role.
IEnumerable<RoleInstanceDiagnosticManager> instanceManagers = diagManager.GetRoleInstanceDiagnosticManagersForRole(roleName);

// Update the sample rate for some performance counters.
PerformanceCounterConfiguration pccCPU = new PerformanceCounterConfiguration();
pccCPU.CounterSpecifier = @"\Processor(_Total)\% Processor Time";
pccCPU.SampleRate = TimeSpan.FromSeconds(20);

PerformanceCounterConfiguration pccMemory = new PerformanceCounterConfiguration();
pccMemory.CounterSpecifier = @"\Memory\Available Mbytes";
pccMemory.SampleRate = TimeSpan.FromSeconds(20);

// Iterate through the role instances and update the configuration.
foreach (var roleInstance in instanceManagers)
{
   DiagnosticMonitorConfiguration currentConfiguration = roleInstance.GetCurrentConfiguration();

   currentConfiguration.PerformanceCounters.DataSources.Add(pccCPU);
   currentConfiguration.PerformanceCounters.DataSources.Add(pccMemory);

   roleInstance.SetCurrentConfiguration(currentConfiguration);
}

Mostrar:
© 2014 Microsoft