Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Provide support for batch scraping #2459

Merged
merged 136 commits into from
Oct 7, 2024
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
136 commits
Select commit Hold shift + click to select a range
163713d
define batch scrape definition model
hkfgo Mar 19, 2024
d0f4c73
implement skeleton batch scraping flow
hkfgo Mar 19, 2024
2552197
complete mapping logic between YAML and scraper domain
hkfgo Mar 20, 2024
975eef7
start grouping logic implementation via compound keys
hkfgo Mar 21, 2024
40289da
flesh out definiion batching logic
hkfgo Mar 21, 2024
e9e385a
implement scraper batch function + hashcode/equals for grouping
hkfgo Mar 23, 2024
d6fe4ff
implement scraper batch function + hashcode/equals for grouping
hkfgo Mar 23, 2024
55b88f9
Merge branch 'master' into feat/enable-batch-scraping
tomkerkhove May 30, 2024
6647ef1
github action image build
hkfgo May 2, 2024
77640a7
github action image build
hkfgo May 2, 2024
3b4ce25
Merge branch 'master' into feat/enable-batch-scraping
tomkerkhove Jul 15, 2024
9e7c0cd
code batch query client initialization
hkfgo Jul 17, 2024
c9bd29b
refactor resource query subroutines as extension methods
hkfgo Jul 18, 2024
43882d6
refactor single resource query subroutine as extension
hkfgo Jul 18, 2024
ff14367
code batch query execution and result processing
hkfgo Jul 19, 2024
3e3ef54
make some compile errors go away
hkfgo Jul 30, 2024
e290f90
make some compile errors go away
hkfgo Jul 30, 2024
c7a3fff
record batch size as histogram metric
hkfgo Jul 31, 2024
f35fce4
restrict batch scraping to only Azure Monitor scraper for now + defin…
hkfgo Aug 2, 2024
e8cf5e1
return resource ID tagged measure metrics in scrape path
hkfgo Aug 2, 2024
10f1599
cache resource info and use cache for hydration
hkfgo Aug 4, 2024
a5966fa
obtain testable build
hkfgo Aug 4, 2024
83761b2
unit test batch property hashcode and equality implementations
hkfgo Aug 8, 2024
94120b5
fix bug in MetricConfiguration to unique string implementation
hkfgo Aug 8, 2024
ca59552
move resource batching routines as separate static class
hkfgo Aug 8, 2024
106bfbd
unit test scrape definition batching logic
hkfgo Aug 9, 2024
cad0752
Move batching to runtime configuration
hkfgo Aug 14, 2024
30b535f
fix test
hkfgo Aug 14, 2024
963b71a
configure CI to do batch scraping
hkfgo Aug 14, 2024
e1a8365
add logging
hkfgo Aug 14, 2024
a93f065
add logging
hkfgo Aug 14, 2024
4342ae2
add logging on scraper
hkfgo Aug 14, 2024
6b0dcbb
add logging on scraper
hkfgo Aug 14, 2024
f773058
add logging on scraper
hkfgo Aug 14, 2024
c3aa159
log exception details
hkfgo Aug 15, 2024
3539362
add more logging on query tasks
hkfgo Aug 15, 2024
3cc8359
make region configurable
hkfgo Aug 16, 2024
7a8fc27
try fixing regional metrics URL
hkfgo Aug 16, 2024
bb71f0d
fix batch API URL formatting
hkfgo Aug 17, 2024
c79750d
fix batch API URL formatting
hkfgo Aug 17, 2024
5a1fc33
debug query range
hkfgo Aug 17, 2024
be7b18b
use different time range instantiation
hkfgo Aug 17, 2024
a58318f
use different time range instantiation
hkfgo Aug 17, 2024
187459c
lower case aggregations
hkfgo Aug 17, 2024
fdabad9
do not use size when filter not present
hkfgo Aug 17, 2024
b2cfd79
log filter
hkfgo Aug 17, 2024
dd9d248
log more query params
hkfgo Aug 17, 2024
a90bf15
log outgoing requests
hkfgo Aug 17, 2024
f2d51f2
try without time range first, because Azure SDK is buggy :(
hkfgo Aug 17, 2024
6406cbe
log ID resposne
hkfgo Aug 17, 2024
be8638c
try new regex for resource ID parsing
hkfgo Aug 19, 2024
3e8e095
process metrics results as IGroup
hkfgo Aug 19, 2024
694a856
log resource definition cache
hkfgo Aug 19, 2024
63d9a03
log resource definition cache
hkfgo Aug 19, 2024
71fb195
log individual resource definitions
hkfgo Aug 19, 2024
f02eaaa
fill out cached resource definitions
hkfgo Aug 19, 2024
6a0d2bf
fix fix
hkfgo Aug 19, 2024
78bf03c
correct aggregation interval processing
hkfgo Sep 9, 2024
7e583a9
try range query again
hkfgo Sep 9, 2024
802a9d2
try modify date range on outgoing requests
hkfgo Sep 10, 2024
b26c9aa
try modify date range on outgoing requests
hkfgo Sep 10, 2024
e85c255
try modify date range on outgoing requests
hkfgo Sep 10, 2024
0dba964
try modify date range on outgoing requests
hkfgo Sep 10, 2024
604ad76
run single resource scraping for comparison
hkfgo Sep 10, 2024
5b0b4cd
run single resource scraping for comparison
hkfgo Sep 10, 2024
cb1b696
go back to batch scraping CI
hkfgo Sep 10, 2024
834819d
create GitHub Action to build image under personal account(will revert)
hkfgo Sep 10, 2024
a3410b8
implement LogAnalytics batch scraping by composing single-resource sc…
hkfgo Sep 12, 2024
70e4a3f
fix bug writing histogram as gauge
hkfgo Sep 12, 2024
de785df
don't throw in OpenTelemetry sink
hkfgo Sep 12, 2024
0b463e7
don't throw in OpenTelemetry sink
hkfgo Sep 12, 2024
082a6e6
set better buckets for batch size
hkfgo Sep 12, 2024
beab4e6
correct logic to determine LogAnalytics aggregation interval
hkfgo Sep 12, 2024
6c721ab
add more debug logging
hkfgo Sep 12, 2024
5d8b5ef
handle single dimension in batching logic
hkfgo Sep 12, 2024
fc0362d
account for limit
hkfgo Sep 12, 2024
4dff71b
add debug logging for resource ID metrics
hkfgo Sep 12, 2024
cbc7e06
add forward slash in front of resource ID
hkfgo Sep 13, 2024
30aa153
improve regex matching
hkfgo Sep 13, 2024
2a42416
Merge branch 'master' into feat/enable-batch-scraping
hkfgo Sep 14, 2024
b77903d
add more debug logging
hkfgo Sep 17, 2024
a2da4a5
use configured max batch size
hkfgo Sep 17, 2024
124acbc
use cached resource definition
hkfgo Sep 18, 2024
c5fd2be
go back
hkfgo Sep 18, 2024
51e589f
go back
hkfgo Sep 18, 2024
3760629
use an older collector version
hkfgo Sep 19, 2024
4853b3e
use different string matching
hkfgo Sep 19, 2024
e2a013f
run prom exporter on localhost
hkfgo Sep 19, 2024
c29399a
try insecure flag
hkfgo Sep 19, 2024
027254b
fix style issues
hkfgo Sep 19, 2024
d0c7b41
use associated resource definition during processing
hkfgo Sep 19, 2024
46931e8
don't use resource-specific filters
hkfgo Sep 20, 2024
d4a0545
Merge branch 'master' into feat/enable-batch-scraping
tomkerkhove Sep 23, 2024
8a0e380
Merge branch 'master' into feat/enable-batch-scraping
tomkerkhove Sep 24, 2024
d88c53b
fix style issues
hkfgo Sep 25, 2024
a853c26
fix style
hkfgo Sep 25, 2024
430c725
Address comments
hkfgo Sep 26, 2024
11d765c
more style fixes
hkfgo Sep 26, 2024
5d38684
consolidate some logging
hkfgo Sep 26, 2024
b3eb049
more style fixes :(
hkfgo Sep 26, 2024
9073887
add null check
hkfgo Sep 26, 2024
e1c96b1
avoid naming collision
hkfgo Sep 26, 2024
172cd33
fix fix style
hkfgo Sep 26, 2024
299ec6e
make config settable
hkfgo Sep 26, 2024
b2d3458
get rid of some redundant code
hkfgo Sep 26, 2024
47672d6
Fighting resharper
hkfgo Sep 26, 2024
06e404d
Fighting resharper
hkfgo Sep 26, 2024
af638b0
add null check
hkfgo Sep 26, 2024
4573300
add null check
hkfgo Sep 26, 2024
9f25804
add simple unit test
hkfgo Sep 26, 2024
943e437
Revert CI workflow changes
hkfgo Sep 26, 2024
88f43cc
get rid of excessive logging
hkfgo Sep 26, 2024
c790b54
add a link to docs
hkfgo Sep 26, 2024
ce56dbb
close ref
hkfgo Sep 26, 2024
04ff115
do not initialize batch client under single-resource scraping
hkfgo Sep 26, 2024
31669c5
handle windows time
hkfgo Sep 26, 2024
b82b73d
(temporary) change GitHub action to build another Linux image
hkfgo Sep 30, 2024
c4b1041
revert back GitHub Action chagnes
hkfgo Oct 1, 2024
fa2fc3f
ci changes
hkfgo Oct 1, 2024
216812b
add logging
hkfgo Oct 1, 2024
c7a4a6a
add logging
hkfgo Oct 1, 2024
e27d581
add logging
hkfgo Oct 1, 2024
f1a2c48
add logging
hkfgo Oct 1, 2024
c72bda1
disable ReSharper when modifying outgoing URL
hkfgo Oct 1, 2024
206e155
remove some more logging + add null checks
hkfgo Oct 1, 2024
67bf0a5
remove some more logging + add null checks
hkfgo Oct 1, 2024
f04cb87
remove some more logging + add null checks
hkfgo Oct 1, 2024
377bdfd
remove some more logging + add null checks
hkfgo Oct 1, 2024
431f37d
remove some more logging + add null checks
hkfgo Oct 1, 2024
86b4ddd
do not run batch mode in CI
hkfgo Oct 1, 2024
eb6d676
trigger CI again
hkfgo Oct 1, 2024
f2e0087
Modify workflow file again
hkfgo Oct 1, 2024
fedf814
revert GitHubaction
hkfgo Oct 1, 2024
988da9b
remove more debug logging
hkfgo Oct 1, 2024
fd14f63
retry-ci
hkfgo Oct 1, 2024
1face30
retry-ci
hkfgo Oct 2, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
71 changes: 69 additions & 2 deletions src/Promitor.Agents.Scraper/Scheduling/ResourcesScrapingJob.cs
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,16 @@
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using Promitor.Agents.Scraper.Discovery.Interfaces;
using Promitor.Agents.Scraper.Validation.MetricDefinitions.ResourceTypes;
using Promitor.Core;
using Promitor.Core.Contracts;
using Promitor.Core.Metrics.Interfaces;
using Promitor.Core.Metrics.Sinks;
using Promitor.Core.Scraping;
using Promitor.Core.Scraping.Configuration.Model;
using Promitor.Core.Scraping.Configuration.Model.Metrics;
using Promitor.Core.Scraping.Factories;
using Promitor.Core.Scraping.ResourceTypes;
using Promitor.Integrations.Azure.Authentication;
using Promitor.Integrations.AzureMonitor.Configuration;
using Promitor.Integrations.LogAnalytics;
Expand Down Expand Up @@ -133,7 +137,6 @@
try
{
var scrapeDefinitions = await GetAllScrapeDefinitions(cancellationToken);

await ScrapeMetrics(scrapeDefinitions, cancellationToken);
}
catch (OperationCanceledException)
Expand Down Expand Up @@ -250,8 +253,19 @@
}

private async Task ScrapeMetrics(IEnumerable<ScrapeDefinition<IAzureResourceDefinition>> scrapeDefinitions, CancellationToken cancellationToken)
{
{
var tasks = new List<Task>();
var batchScrapingEnabled = this._metricsDeclaration.MetricBatchConfig?.Enabled ?? false;
if (batchScrapingEnabled) {
var batchScrapeDefinitions = GroupScrapeDefinitions(scrapeDefinitions, this._metricsDeclaration.MetricBatchConfig.MaxBatchSize, cancellationToken);

foreach(var batchScrapeDefinition in batchScrapeDefinitions) {
var azureMetricName = batchScrapeDefinition.AzureMetricConfiguration.MetricName;
var resourceType = batchScrapeDefinition.ResourceType;
Logger.LogInformation("Batch scraping Azure Metric {AzureMetricName} for resource type {ResourceType}.", azureMetricName, resourceType);
await ScheduleLimitedConcurrencyAsyncTask(tasks, () => ScrapeMetricBatched(batchScrapeDefinition), cancellationToken);
}
}

foreach (var scrapeDefinition in scrapeDefinitions)
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
{
Expand All @@ -266,6 +280,28 @@

await Task.WhenAll(tasks);
}
private async Task ScrapeMetricBatched(BatchScrapeDefinition<IAzureResourceDefinition> batchScrapeDefinition) {
try
{
var resourceSubscriptionId = batchScrapeDefinition.ScrapeDefinitionBatchProperties.SubscriptionId;
var azureMonitorClient = _azureMonitorClientFactory.CreateIfNotExists(_metricsDeclaration.AzureMetadata.Cloud, _metricsDeclaration.AzureMetadata.TenantId,
resourceSubscriptionId, _metricSinkWriter, _azureScrapingSystemMetricsPublisher, _resourceMetricDefinitionMemoryCache, _configuration,
_azureMonitorIntegrationConfiguration, _azureMonitorLoggingConfiguration, _loggerFactory);

var tokenCredential = AzureAuthenticationFactory.GetTokenCredential(_metricsDeclaration.AzureMetadata.Cloud.ManagementEndpoint, _metricsDeclaration.AzureMetadata.TenantId,
AzureAuthenticationFactory.GetConfiguredAzureAuthentication(_configuration), new Uri(_metricsDeclaration.AzureMetadata.Cloud.AuthenticationEndpoint));
var logAnalyticsClient = new LogAnalyticsClient(_loggerFactory, _metricsDeclaration.AzureMetadata.Cloud, tokenCredential);

var scraper = _metricScraperFactory.CreateScraper(scrapeDefinition.Resource.ResourceType, _metricSinkWriter, _azureScrapingSystemMetricsPublisher, azureMonitorClient, logAnalyticsClient);

await scraper.BatchScrapeAsync(batchScrapeDefinition);
}
catch (Exception ex)
{
Logger.LogError(ex, "Failed to scrape metric {MetricName} for resource batch {ResourceName}.",
scrapeDefinition.PrometheusMetricDefinition.Name, batchScrapeDefinition.ScrapeDefinitionBatchProperties);
}
}

private async Task ScrapeMetric(ScrapeDefinition<IAzureResourceDefinition> scrapeDefinition)
{
Expand All @@ -284,6 +320,7 @@
var logAnalyticsClient = new LogAnalyticsClient(_loggerFactory, _metricsDeclaration.AzureMetadata.Cloud, tokenCredential);

var scraper = _metricScraperFactory.CreateScraper(scrapeDefinition.Resource.ResourceType, _metricSinkWriter, _azureScrapingSystemMetricsPublisher, azureMonitorClient, logAnalyticsClient);

await scraper.ScrapeAsync(scrapeDefinition);
}
catch (Exception ex)
Expand All @@ -292,7 +329,37 @@
scrapeDefinition.PrometheusMetricDefinition.Name, scrapeDefinition.Resource.ResourceName);
}
}

/// <summary>
/// groups scrape definitions based on following conditions:
/// 1. Definitions in a batch must target the same resource type
/// 2. Definitions in a batch must target the same Azure metric with identical dimensions
/// 3. Definitions in a batch must have the same time granularity
/// 4. Batch size cannot exceed configured maximum
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
/// </summary>
private List<BatchScrapeDefinition<IAzureResourceDefinition>> GroupScrapeDefinitions(IEnumerable<ScrapeDefinition<IAzureResourceDefinition>> allScrapeDefinitions, int maxBatchSize, CancellationToken cancellationToken)
{

Check notice on line 341 in src/Promitor.Agents.Scraper/Scheduling/ResourcesScrapingJob.cs

View check run for this annotation

codefactor.io / CodeFactor

src/Promitor.Agents.Scraper/Scheduling/ResourcesScrapingJob.cs#L341

An opening curly bracket must not be followed by a blank line. (SA1505)

Dictionary<ScrapeDefinitionBatchProperties, List<ScrapeDefinition<IAzureResourceDefinition>>> groupedScrapeDefinitions = allScrapeDefinitions.GroupBy(def => def.buildPropertiesForBatch())
.ToDictionary(group => group.Key, group => group.ToList()) // first pass to build batches that could exceed max
.ToDictionary(group => group.Key, SplitScrapeDefinitionBatch(group.Value)) // split to right-sized batches
.SelectMany(group => group.Value.SelectMany(batch => new BatchScrapeDefinition(batch, group.Key))); // flatten
return groupedScrapeDefinitions;
}

/// <summary>
/// splits the "raw" batch according to max batch size configured
/// </summary>
private List<List<BatchScrapeDefinition<IAzureResourceDefinition>>> SplitScrapeDefinitionBatch(List<ScrapeDefinition> batchToSplit, int maxBatchSize, CancellationToken cancellationToken)
{
int numNewGroups = (batchToSplit.Count - 1) / 50 + 1;

Check notice on line 355 in src/Promitor.Agents.Scraper/Scheduling/ResourcesScrapingJob.cs

View check run for this annotation

codefactor.io / CodeFactor

src/Promitor.Agents.Scraper/Scheduling/ResourcesScrapingJob.cs#L355

Insert parentheses within the arithmetic expression to declare the operator precedence. (SA1407)

return Enumerable.Range(0, batchToSplit)
.Select(i => batchToSplit.Skip(i * 50).Take(50).ToList())
.ToList();
}


Check notice on line 362 in src/Promitor.Agents.Scraper/Scheduling/ResourcesScrapingJob.cs

View check run for this annotation

codefactor.io / CodeFactor

src/Promitor.Agents.Scraper/Scheduling/ResourcesScrapingJob.cs#L362

The code must not contain multiple blank lines in a row. (SA1507)
/// <summary>
/// Run some task work in the thread pool, but only allow a limited number of threads to go at a time
/// (unless max degree of parallelism wasn't configured, in which case mutex is null and no limit is imposed).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,5 +45,20 @@ public class AzureMetricConfiguration
}
return Dimensions?.Any(dimension => dimension.Name.Equals(dimensionName, StringComparison.InvariantCultureIgnoreCase));
}

// A unique string to represent this Azure metric and its configured dimensions
public string ToUniqueStringRepresentation()
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
{
StringBuilder sb = new StringBuilder();
sb.Append(Name);

foreach (var dimension in Dimensions)
{
sb.Append("_");
sb.Append(dimension.ToString());
}

return sb.ToString();
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace Promitor.Core.Scraping.Configuration.Model
{
public class MetricBatchScrapeConfig
{
public bool Enabled { get; set; }
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
public int MaxBatchSize { get; set; }
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
using System;
using System.Collections.Generic;
using GuardNet;
using Promitor.Core.Contracts;

namespace Promitor.Core.Scraping.Configuration.Model.Metrics
{
/// <summary>
/// Defines a batch of ScrapeDefinitions to be executed in a single request
/// Scrape definitions within a batch should share
/// 1. The same resource type
/// 2. The same Azure metric scrape target with identical dimensions
/// 3. The same time granularity
/// </summary>
public class BatchScrapeDefinition<TResourceDefinition> where TResourceDefinition : class, IAzureResourceDefinition
{
/// <summary>
/// Creates a new instance of the <see cref="ScrapeDefinition{TResourceDefinition}"/> class.
/// </summary>
/// <param name="azureMetricConfiguration">Configuration about the Azure Monitor metric to scrape</param>
/// <param name="azureMetricConfiguration">Configuration about the Azure Monitor metric to scrape</param>
/// <param name="scraping">The scraping model.</param>
/// <param name="subscriptionId">Specify a subscription to scrape that defers from the default subscription.</param>
/// <param name="resourceGroupName">
/// The name of the resource group containing the resource to scrape. This should contain the global
/// resource group name if none is overridden at the resource level.
/// </param>
public BatchScrapeDefinition(List<ScrapeDefinition<TResourceDefinition>> groupedScrapeDefinitions, ScrapeDefinitionBatchProperties scrapeDefinitionBatchProperties)
{
Guard.NotNull(groupedScrapeDefinitions, nameof(groupedScrapeDefinitions));
Guard.NotNull(groupedScrapeDefinitions, nameof(scrapeDefinitionBatchProperties));
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
hkfgo marked this conversation as resolved.
Show resolved Hide resolved

ScrapeDefinitions = groupedScrapeDefinitions;
ScrapeDefinitionBatchProperties = scrapeDefinitionBatchProperties;
}

/// <summary>
/// A batch of scrape job definitions to be executed as a single request
/// </summary>
public List<ScrapeDefinition<TResourceDefinition>> ScrapeDefinitions { get; set; } = new List<ScrapeDefinition<TResourceDefinition>>();

public ScrapeDefinitionBatchProperties ScrapeDefinitionBatchProperties { get; set; }
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -94,5 +94,14 @@ public ScrapeDefinition(
}
return AzureMetricConfiguration?.Aggregation?.Interval;
}

public ScrapeDefinitionBatchProperties buildPropertiesForBatch() {
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
return new ScrapeDefinitionBatchProperties(
this.AzureMetricConfiguration,
this.SubscriptionId,
this.Resource.ResourceType,
this.GetAggregationInterval
);
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
using System;
using System.Collections.Generic;
using Promitor.Core.Contracts;

namespace Promitor.Core.Scraping.Configuration.Model.Metrics
{
/// <summary>
/// Defines properties of a batch of scrape definitions
/// </summary>
public class ScrapeDefinitionBatchProperties : IEquatable<ScrapeDefinitionBatchProperties>

Check failure on line 10 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

'ScrapeDefinitionBatchProperties' does not implement interface member 'IEquatable<ScrapeDefinitionBatchProperties>.Equals(ScrapeDefinitionBatchProperties?)'
{

}

/// <summary>
/// Configuration about the Azure Monitor metric to scrape
/// </summary>
public AzureMetricConfiguration AzureMetricConfiguration { get; }

Check failure on line 18 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements


/// <summary>
/// The scraping model.
/// </summary>
public Scraping Scraping { get; }

Check failure on line 24 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements

/// <summary>
/// The Azure subscription to get the metric from. This should be used instead of using
/// the SubscriptionId from <see cref="Resource"/> because this property will contain
/// the global subscription id if none is overridden at the resource level.
/// </summary>
public string SubscriptionId { get; }

Check failure on line 31 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements

/// <summary>
/// The Azure resource type shared by all scrape definitions in the batch
/// </summary>
public ResourceType ResourceType { get; }

Check failure on line 36 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements

public TimeSpan AggregationInterval{ get; }

Check failure on line 38 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements

public override int GetHashCode()

Check failure on line 40 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
{
return this.BuildBatchHashKey().GetHashCode();
}

/// <summary>
/// Builds a namespaced string key to satisfy batch restrictions, in the format of
/// <AzureMetricAndDimensions>_<SubscriptionId>_<ResourceType>_<AggregationInterval>
/// </summary>
private string BuildBatchHashKey()

Check failure on line 49 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements
{
return string.Join("_", [List.ofAzureMetricConfiguration.ToUniqueStringRepresentation(), SubscriptionId, ResourceType.ToString(), AggregationInterval.ToString]);
}

/// <summary>
/// Equality comparison override in case of hash collision
/// </summary>
public override bool Equals(object obj)

Check failure on line 57 in src/Promitor.Core.Scraping/Configuration/Model/Metrics/ScrapeDefinitionBatch.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

A namespace cannot directly contain members such as fields, methods or statements
hkfgo marked this conversation as resolved.
Show resolved Hide resolved
{
if (obj == null || !(obj is ScrapeDefinitionBatchProperties))
return false;

MyClass other = (ScrapeDefinitionBatchProperties)obj;
return this.ResourceType == other.ResourceType && this.AzureMetricConfiguration.ToUniqueStringRepresentation() == other.ToUniqueStringRepresentation() && this.SubscriptionId == other.SubscriptionId && this.AggregationInterval.Equals(other.AggregationDeserializer);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
public class MetricsDeclaration
{
public AzureMetadata AzureMetadata { get; set; }
public MetricBatchScrapeConfig? MetricBatchConfig { get; set; }

Check warning on line 9 in src/Promitor.Core.Scraping/Configuration/Model/MetricsDeclaration.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.

Check warning on line 9 in src/Promitor.Core.Scraping/Configuration/Model/MetricsDeclaration.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.

Check warning on line 9 in src/Promitor.Core.Scraping/Configuration/Model/MetricsDeclaration.cs

View workflow job for this annotation

GitHub Actions / Analyse

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.

Check warning on line 9 in src/Promitor.Core.Scraping/Configuration/Model/MetricsDeclaration.cs

View workflow job for this annotation

GitHub Actions / Analyse

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.
public MetricDefaults MetricDefaults { get; set; } = new MetricDefaults();
public List<MetricDefinition> Metrics { get; set; } = new List<MetricDefinition>();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ public V1MappingProfile()
{
CreateMap<MetricsDeclarationV1, MetricsDeclaration>();
CreateMap<AzureMetadataV1, AzureMetadata>();
CreateMap<MetricBatchScrapeConfigV1, MetricBatchScrapeConfig>();
CreateMap<MetricDefaultsV1, MetricDefaults>();
CreateMap<AggregationV1, Aggregation>();
CreateMap<MetricDimensionV1, MetricDimension>();
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
using System;
using Microsoft.Azure.Management.Monitor.Fluent.Models;

namespace Promitor.Core.Scraping.Configuration.Serialization.v1.Model
{
/// <summary>
/// Contains settings to scrape metrics in batched API calls
/// </summary>
public class MetricBatchScrapeConfigV1
{
/// <summary>
/// Enable batched scraping mode for all metrics in the scraper
/// </summary>
public bool Enabled { get; set; }

/// <summary>
/// Maximum number of resources in a batch. Azure Monitor API specifies a max limit of 50 as of March 2024
/// </summary>
public int MaxBatchSize { get; set; }
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
using System.Collections.Generic;
using Promitor.Core.Scraping.Configuration.Model;
using Promitor.Core.Serialization.Enum;

namespace Promitor.Core.Scraping.Configuration.Serialization.v1.Model
Expand All @@ -10,6 +11,7 @@
{
public string Version { get; set; } = SpecVersion.v1.ToString();
public AzureMetadataV1 AzureMetadata { get; set; }
public MetricBatchScrapeConfigV1? MetricBatchScrapeConfig { get; set; }

Check warning on line 14 in src/Promitor.Core.Scraping/Configuration/Serialization/v1/Model/MetricsDeclarationV1.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.

Check warning on line 14 in src/Promitor.Core.Scraping/Configuration/Serialization/v1/Model/MetricsDeclarationV1.cs

View workflow job for this annotation

GitHub Actions / Verify Codebase

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.

Check warning on line 14 in src/Promitor.Core.Scraping/Configuration/Serialization/v1/Model/MetricsDeclarationV1.cs

View workflow job for this annotation

GitHub Actions / Analyse

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.

Check warning on line 14 in src/Promitor.Core.Scraping/Configuration/Serialization/v1/Model/MetricsDeclarationV1.cs

View workflow job for this annotation

GitHub Actions / Analyse

The annotation for nullable reference types should only be used in code within a '#nullable' annotations context.
public MetricDefaultsV1 MetricDefaults { get; set; }
public IReadOnlyCollection<MetricDefinitionV1> Metrics { get; set; }
}
Expand Down
1 change: 1 addition & 0 deletions src/Promitor.Core.Scraping/Interfaces/IScraper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,6 @@ namespace Promitor.Core.Scraping.Interfaces
public interface IScraper<TResourceDefinition> where TResourceDefinition : class, IAzureResourceDefinition
{
Task ScrapeAsync(ScrapeDefinition<TResourceDefinition> scrapeDefinition);
Task BatchScrapeAsync(BatchScrapeDefinition<TResourceDefinition> batchScrapeDefinition);
}
}
Loading
Loading