public async Task TestListSparkApplications() { SparkJobListViewResponse sparkJobList = await MonitoringClient.GetSparkJobListAsync(); Assert.NotNull(sparkJobList); CollectionAssert.IsNotEmpty(sparkJobList.SparkJobs); }
public void MonitorPipelineRuns() { #region Snippet:CreateMonitoringClient string endpoint = TestEnvironment.EndpointUrl; MonitoringClient client = new MonitoringClient(new Uri(endpoint), new DefaultAzureCredential()); #endregion #region Snippet:GetSparkJobList SparkJobListViewResponse sparkJobList = client.GetSparkJobList(); foreach (var sparkJob in sparkJobList.SparkJobs) { if (sparkJob.State == "Running") { Console.WriteLine($"{sparkJob.Name} has been running for {sparkJob.RunningDuration}"); } else { Console.WriteLine($"{sparkJob.Name} has been in {sparkJob.State} for {sparkJob.QueuedDuration}"); } } #endregion #region Snippet:GetSqlJobQueryString SqlQueryStringDataModel sqlQuery = client.GetSqlJobQueryString(); #endregion }
public async Task TestSqlQuery() { SqlQueryStringDataModel sqlQuery = await MonitoringClient.GetSqlJobQueryStringAsync(); Assert.NotNull(sqlQuery); Assert.IsNotNull(sqlQuery.Query); }
protected override void ProcessRecord() { base.ProcessRecord(); client?.Dispose(); client = new MonitoringClient(AuthProvider, new Oci.Common.ClientConfiguration { RetryConfiguration = retryConfig, TimeoutMillis = TimeOutInMillis, ClientUserAgent = PSUserAgent }); try { string region = GetPreferredRegion(); if (region != null) { WriteDebug("Choosing Region:" + region); client.SetRegion(region); } if (Endpoint != null) { WriteDebug("Choosing Endpoint:" + Endpoint); client.SetEndpoint(Endpoint); } } catch (Exception ex) { TerminatingErrorDuringExecution(ex); } }
public static async Task TestAlgoliaMonitoringClient() { System.Console.WriteLine("~~*\\#/*~~ Algolia Client API playground to test the MonitoringClient ~~*\\#/*~~"); System.Console.WriteLine("please enter Algolia applicationId: "); var applicationId = System.Console.ReadLine(); System.Console.WriteLine("please enter Algolia monitoringApiKey: "); var monitoringApiKey = System.Console.ReadLine(); var client = new MonitoringClient(applicationId, monitoringApiKey); System.Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); System.Console.WriteLine("### Algolia Monitoring API - Status - Get current ###"); System.Console.WriteLine("*** results below ***"); ServerStatus server = null; try { server = await client.GetCurrentStatusServerAsync(); System.Console.WriteLine(server.ToString()); } catch (MonitoringClientException ex) { System.Console.WriteLine(ex.Message); } System.Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); System.Console.WriteLine("### Algolia Monitoring API - Status - Get current servers ###"); Program.DisplayStatusUsage(); string[] servers = null; while (servers == null) { System.Console.WriteLine("You turn to enter server name(s) now: "); // almost no input validation done here at the console level var serverNameInput = System.Console.ReadLine(); servers = Program.GetServerFromInput(serverNameInput); } System.Console.WriteLine("*** results below ***"); Dictionary <string, ServerStatus> serversDic = null; try { serversDic = await client.GetCurrentStatusServersAsync(servers); Program.DisplayStatus(serversDic); } catch (MonitoringClientException ex) { System.Console.WriteLine($"An exception was thrown by the Monitoring Client API. The exception message is : {ex.Message}"); } }
public static void Main(string[] args) { SetupDatabaseConnections(); var mq = new MonitoringClient(GetMonitoredState, "kaos_monitored_state_queue", TimeSpan.FromSeconds(1)); mq.Run(); }
public async Task MonitoringClient_DummyMethodeName_ShouldSucceed() { // arrange var client = new MonitoringClient(Environment.GetEnvironmentVariable("ALGOLIA_APPLICATION_ID_TEST"), "ALGOLIA_API_KEY_TEST"); // act var result = await client.GetCurrentStatusServerAsync(); // assert result.Should().NotBeNull(); }
public void CreateClient() { // Environment variable with the Synapse workspace endpoint. string workspaceUrl = TestEnvironment.WorkspaceUrl; #region Snippet:CreateMonitoringClient // Create a new monitoring client using the default credential from Azure.Identity using environment variables previously set, // including AZURE_CLIENT_ID, AZURE_CLIENT_SECRET, and AZURE_TENANT_ID. MonitoringClient client = new MonitoringClient(endpoint: new Uri(workspaceUrl), credential: new DefaultAzureCredential()); #endregion this.client = client; }
public void MonitoringSample() { #region Snippet:CreateMonitoringClient // Replace the string below with your actual endpoint url. string endpoint = "<my-endpoint-url>"; /*@@*/ endpoint = TestEnvironment.EndpointUrl; MonitoringClient client = new MonitoringClient(endpoint: new Uri(endpoint), credential: new DefaultAzureCredential()); #endregion #region Snippet:GetSparkJobList SparkJobListViewResponse sparkJobList = client.GetSparkJobList(); #endregion #region Snippet:GetSqlJobQueryString SqlQueryStringDataModel sqlQuery = client.GetSqlJobQueryString(); #endregion }
public static void MonitoringResourceExample(ClientConfig config) { // create client var identityClient = new IdentityClient(config); var computeClient = new ComputeClient(config); var monitoringClient = new MonitoringClient(config); var listCompartmenRequest = new ListCompartmentRequest() { CompartmentId = identityClient.Config.TenancyId, CompartmentIdInSubtree = true, AccessLevel = ListCompartmentRequest.AccessLevels.ACCESSIBLE, Limit = 10 }; // get compartment var listCompartment = identityClient.ListCompartment(listCompartmenRequest).Items; Console.WriteLine("* List Instance Metrics------------------------"); foreach (var compartment in listCompartment) { if (!compartment.IsAccessible.HasValue || !compartment.IsAccessible.Value) { continue; } var listInstanceRequest = new ListInstancesRequest() { CompartmentId = compartment.Id, Limit = 50, LifecycleState = ListInstancesRequest.LifecycleStates.RUNNING, SortOrder = SortOrder.ASC }; var now = DateTime.UtcNow.AddHours(-2); var endTime = DateTime.UtcNow; // get instance var listInstance = computeClient.ListInstances(listInstanceRequest).Items; foreach (var instance in listInstance) { Console.WriteLine($" |-{instance.DisplayName}------------"); // get all computeagent var listMetricsRequest = new ListMetricsRequest() { CompartmentId = compartment.Id, CompartmentIdInSubtree = compartment.CompartmentId == config.TenancyId, ListMetricsDetails = new ListMetricsDetails() { Namespace = "oci_computeagent", DimensionFilters = new DimensionFilter() { ResourceId = instance.Id } } }; // get Metrics try { var listMetrics = monitoringClient.ListMetrics(listMetricsRequest).Items; foreach (var metrics in listMetrics) { Console.WriteLine($"\t| Mertics: {metrics.Name}"); Console.WriteLine($"\t| NameSpace: {metrics.Namespace}"); // metric dimensions //Console.WriteLine($"\t| {metrics.Dimensions}".Replace("\n", "")); var summarizeMetricsDataRequest = new SummarizeMetricsDataRequest() { CompartmentId = compartment.Id, CompartmentIdInSubtree = compartment.CompartmentId == config.TenancyId, SummarizeMetricsDataDetails = new SummarizeMetricsDataDetails() { Namespace = metrics.Namespace, Query = metrics.Name + "[1h]{resourceId = \"" + instance.Id + "\"}.mean()", StartTime = now.ToString("yyyy-MM-ddThh:MM:ssZ"), EndTime = endTime.ToString("yyyy-MM-ddThh:MM:ssZ") } }; var SummarizeMetricsDatas = monitoringClient.SummarizeMetricsData(summarizeMetricsDataRequest).Items; foreach (var summaryData in SummarizeMetricsDatas) { foreach (var aggregatedDatapoint in summaryData.AggregatedDatapoints) { Console.WriteLine("\t| {"); Console.WriteLine($"\t| \tTimeStamp: {aggregatedDatapoint.Timestamp}"); Console.WriteLine($"\t| \tValue: {aggregatedDatapoint.Value}"); Console.WriteLine("\t| }"); } } } } catch (WebException we) { Console.WriteLine($"notfund:{we.Message}"); } } } Console.WriteLine("* List compartment Alarms------------------------"); foreach (var compartment in listCompartment) { Console.WriteLine(" Alarm status------------------------"); var listAlarmsStatusRequest = new ListAlarmsStatusRequest() { CompartmentId = compartment.Id, Limit = 1000 }; var alarmStatus = monitoringClient.ListAlarmsStatus(listAlarmsStatusRequest); if (alarmStatus.Items.Count > 0) { Console.WriteLine($" |-{compartment.Name}------------"); foreach (var alarm in alarmStatus.Items) { Console.WriteLine($"\tid:{alarm.Id}"); Console.WriteLine($"\tname:{alarm.DisplayName}"); Console.WriteLine($"\tstatus:{alarm.Status}"); Console.WriteLine($"\tseverity:{alarm.Severity}"); } } var listAlarmsRequest = new ListAlarmsRequest() { CompartmentId = compartment.Id, Limit = 10 }; Console.WriteLine(" Alarm logs------------------------"); var listAlarms = monitoringClient.ListAlarms(listAlarmsRequest); if (listAlarms.Items.Count > 0) { Console.WriteLine($" |-{compartment.Name}------------"); foreach (var alarm in listAlarms.Items) { Console.WriteLine($"\tid:{alarm.Id}"); Console.WriteLine($"\tname:{alarm.DisplayName}"); Console.WriteLine($"\tdestinations:{alarm.Destinations}"); Console.WriteLine($"\tenable:{alarm.IsEnabled}"); Console.WriteLine($"\tstate:{alarm.LifecycleState}"); var getAlarmHistoryRequest = new GetAlarmHistoryRequest() { AlarmId = alarm.Id, TimestampGreaterThanOrEqualTo = DateTime.UtcNow.ToString() }; var history = monitoringClient.GetAlarmHistory(getAlarmHistoryRequest); foreach (var his in history.AlarmHistoryCollection.Entries) { Console.WriteLine($"\t\t|-summary:{his.Summary}"); Console.WriteLine($"\t\t| timestamp:{his.Timestamp}"); Console.WriteLine($"\t\t| timestampTriggered:{his.TimestampTriggered}"); } } } // Transactions Per Second (TPS) per-tenancy limit for this operation: 1. System.Threading.Thread.Sleep(1000); } }
public static async Task MainMonitoring() { logger.Info("Starting example"); var provider = new ConfigFileAuthenticationDetailsProvider("DEFAULT"); var compartmentId = Environment.GetEnvironmentVariable("OCI_COMPARTMENT_ID"); var metricCompartmentId = Environment.GetEnvironmentVariable("METRIC_COMPARTMENT_ID"); var destinations = Environment.GetEnvironmentVariable("DESTINATION"); var monitoringClient = new MonitoringClient(provider); string alarmId = null; var alarmDestinations = new List <string>(destinations.Split(',')); try { // Create a new alarm var createAlarmDetails = new CreateAlarmDetails { DisplayName = displayName, CompartmentId = compartmentId, MetricCompartmentId = metricCompartmentId, Namespace = ociNamespace, Query = metricQuery, Resolution = resolution, PendingDuration = pendingDuration, Severity = alertSeverity, Body = body, Destinations = alarmDestinations, RepeatNotificationDuration = repeatDuration, IsEnabled = true }; CreateAlarmRequest createAlarmRequest = new CreateAlarmRequest { CreateAlarmDetails = createAlarmDetails }; var createAlarmResponse = await monitoringClient.CreateAlarm(createAlarmRequest); logger.Info($"Created alarm: {displayName}"); alarmId = createAlarmResponse.Alarm.Id; Suppression suppression = new Suppression { Description = "suppress the alarm", TimeSuppressFrom = suppressFrom, TimeSuppressUntil = suppressUntil }; // Update the new alarm. UpdateAlarmDetails updateAlarmDetails = new UpdateAlarmDetails { Suppression = suppression }; UpdateAlarmRequest updateAlarmRequest = new UpdateAlarmRequest { AlarmId = alarmId, UpdateAlarmDetails = updateAlarmDetails }; UpdateAlarmResponse updateAlarmResponse = await monitoringClient.UpdateAlarm(updateAlarmRequest); logger.Info("Updated alarm"); RemoveAlarmSuppressionRequest removeAlarmSuppressionRequest = new RemoveAlarmSuppressionRequest { AlarmId = alarmId }; RemoveAlarmSuppressionResponse removeAlarmSuppressionResponse = await monitoringClient.RemoveAlarmSuppression(removeAlarmSuppressionRequest); logger.Info("removed suppression for the alarm"); // Get the new alarm GetAlarmRequest getAlarmRequest = new GetAlarmRequest { AlarmId = alarmId }; GetAlarmResponse getAlarmResponse = await monitoringClient.GetAlarm(getAlarmRequest); logger.Info($"Retrieved alarm for id: {getAlarmResponse.Alarm.Id}"); // Get alarm history GetAlarmHistoryRequest getAlarmHistoryRequest = new GetAlarmHistoryRequest { AlarmId = alarmId }; GetAlarmHistoryResponse getAlarmHistoryResponse = await monitoringClient.GetAlarmHistory(getAlarmHistoryRequest); logger.Info($"Alarm history for id: {alarmId}"); foreach (var alarmHistoryEntry in getAlarmHistoryResponse.AlarmHistoryCollection.Entries) { logger.Info($"summary: {alarmHistoryEntry.Summary}"); } // List alarms ListAlarmsRequest listAlarmsRequest = new ListAlarmsRequest { CompartmentId = compartmentId, DisplayName = displayName }; ListAlarmsResponse listAlarmsResponse = await monitoringClient.ListAlarms(listAlarmsRequest); logger.Info("Retrieved alarms"); logger.Info("================="); foreach (var alarmSummary in listAlarmsResponse.Items) { logger.Info($"Alarm: {alarmSummary.DisplayName}"); } // List alarm status ListAlarmsStatusRequest listAlarmsStatusRequest = new ListAlarmsStatusRequest { DisplayName = displayName, CompartmentId = compartmentId }; ListAlarmsStatusResponse listAlarmsStatusResponse = await monitoringClient.ListAlarmsStatus(listAlarmsStatusRequest); logger.Info("Retrieved alarms status"); logger.Info("======================="); foreach (var alarmsStatus in listAlarmsStatusResponse.Items) { logger.Info($"Status of the alarm: {alarmsStatus.DisplayName} is {alarmsStatus.Status}"); } } catch (Exception e) { logger.Error($"Exception: {e}"); } finally { if (alarmId != null) { DeleteAlarmRequest deleteAlarmRequest = new DeleteAlarmRequest { AlarmId = alarmId }; DeleteAlarmResponse deleteAlarmResponse = await monitoringClient.DeleteAlarm(deleteAlarmRequest); logger.Info($"Deleted alam: {displayName}"); } monitoringClient.Dispose(); } logger.Info("End example"); }
public override void StartTestRecording() { base.StartTestRecording(); MonitoringClient = CreateMonitoringClient(); }
public static async Task TestAlgoliaMonitoringClient() { System.Console.WriteLine("~~*\\#/*~~ Algolia Client API playground to test the MonitoringClient ~~*\\#/*~~"); System.Console.WriteLine("please enter Algolia applicationId: "); var applicationId = System.Console.ReadLine(); System.Console.WriteLine("please enter Algolia monitoringApiKey: "); var monitoringApiKey = System.Console.ReadLine(); var client = new MonitoringClient(applicationId, monitoringApiKey); System.Console.WriteLine($"{Environment.NewLine}~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); System.Console.WriteLine("### Algolia Monitoring API - Status - Get current ###"); GetServerStatusResponse response1 = null; try { response1 = await client.GetServerStatusAsync(); System.Console.WriteLine("*** results below ***"); Program.DisplayServerStatusResponse(response1); } catch (Exception ex) { System.Console.WriteLine($"Oops ! there was a problem."); System.Console.WriteLine(ex.Message); System.Console.WriteLine($".... let's keep running the program anyway !"); } System.Console.WriteLine($"{Environment.NewLine}~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); System.Console.WriteLine("### Algolia Monitoring API - Status - Get current servers ###"); Program.DisplayUsage(); GetServerStatusResponse response2 = null; while (response2 == null) { System.Console.WriteLine("You turn to enter server name(s) now: "); // almost no input validation done here at the console level var serverNameInput = System.Console.ReadLine(); try { response2 = await client.GetServerStatusAsync(serverNameInput); System.Console.WriteLine("*** results below ***"); Program.DisplayServerStatusResponse(response2); } catch (Exception ex) { System.Console.WriteLine($"Oops ! there was a problem."); System.Console.WriteLine(ex.Message); System.Console.WriteLine($".... let's keep running the program anyway !"); } } System.Console.WriteLine($"{Environment.NewLine}~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); System.Console.WriteLine("### Algolia Monitoring API - Incident - List last incidents ###"); ListServerIncidentsResponse response3 = null; try { response3 = await client.ListIncidentsAsync(); System.Console.WriteLine("*** results below ***"); Program.DisplayServerIncidentsResponse(response3); } catch (Exception ex) { System.Console.WriteLine($"Oops ! there was a problem."); System.Console.WriteLine(ex.Message); System.Console.WriteLine($".... let's keep running the program anyway !"); } System.Console.WriteLine($"{Environment.NewLine}~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); System.Console.WriteLine("### Algolia Monitoring API - Incident - List last incidents for servers ###"); Program.DisplayUsage(); ListServerIncidentsResponse response4 = null; while (response4 == null) { System.Console.WriteLine("You turn to enter server name(s) now: "); // almost no input validation done here at the console level var serverNameInput = System.Console.ReadLine(); try { response4 = await client.ListIncidentsAsync(serverNameInput); System.Console.WriteLine("*** results below ***"); Program.DisplayServerIncidentsResponse(response4); } catch (Exception ex) { System.Console.WriteLine($"Oops ! there was a problem."); System.Console.WriteLine(ex.Message); System.Console.WriteLine($".... let's keep running the program anyway !"); } } System.Console.WriteLine($"{Environment.NewLine}~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); System.Console.WriteLine($"We are done. See you soon !"); }