Modificare in modalità remota la configurazione del monitoraggio Diagnostica

Aggiornamento: novembre 2015

Dopo aver distribuito un servizio cloud, è possibile modificare in modalità remota la configurazione del monitoraggio di diagnostica dal codice eseguito in un'applicazione esternamente ad Azure utilizzando la classe DeploymentDiagnosticManager. Da questa classe, è possibile modificare i monitoraggi Diagnostica per una o più istanze del ruolo. È anche possibile modificare la configurazione del monitoraggio Diagnostica per una sola istanza del ruolo utilizzando la classe RoleInstanceDiagnosticManager.

noteNota
Si applica ad Azure SDK 2.4 e versioni precedenti.

Nell'esempio seguente viene aggiornata in modalità remota la raccolta di due contatori di prestazioni in un servizio cloud. Aggiungere un riferimento al progetto a Microsoft.WindowsAzure.Diagnostics.dll, installato nella directory %Program Files%\Microsoft SDKs\Windows Azure.NET SDK\<num-versione>\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);
}

Mostra: