Skip to content

Commit

Permalink
logging
Browse files Browse the repository at this point in the history
Signed-off-by: Piotr Karpala <piotrkarpala@microsoft.com>
  • Loading branch information
karpikpl committed Jun 13, 2024
1 parent 61df8d9 commit 3dc96e3
Show file tree
Hide file tree
Showing 7 changed files with 55 additions and 8 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -452,3 +452,4 @@ $RECYCLE.BIN/
!.vscode/tasks.json
!.vscode/launch.json
!.vscode/extensions.json
src/Scaler.Demo/OrderProcessor/appsettings.Development.json
25 changes: 25 additions & 0 deletions .vscode/launch.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,31 @@
"name": ".NET Core Attach",
"type": "coreclr",
"request": "attach"
},
{
// Use IntelliSense to find out which attributes exist for C# debugging
// Use hover for the description of the existing attributes
// For further information visit https://github.com/OmniSharp/omnisharp-vscode/blob/master/debugger-launchjson.md
"name": "Order Processor",
"type": "coreclr",
"request": "launch",
"preLaunchTask": "build",
// If you have changed target frameworks, make sure to update the program path.
"program": "${workspaceFolder}/src/Scaler.Demo/OrderProcessor/bin/Debug/net6.0/Keda.CosmosDb.Scaler.Demo.OrderProcessor.dll",
"args": [],
"cwd": "${workspaceFolder}/src/Scaler.Demo/OrderProcessor",
"stopAtEntry": false,
// Enable launching a web browser when ASP.NET Core starts. For more information: https://aka.ms/VSCode-CS-LaunchJson-WebBrowser
"serverReadyAction": {
"action": "openExternally",
"pattern": "\\bNow listening on:\\s+(https?://\\S+)"
},
"env": {
"ASPNETCORE_ENVIRONMENT": "Development",
},
"sourceFileMap": {
"/Views": "${workspaceFolder}/Views"
}
}
]
}
11 changes: 8 additions & 3 deletions src/Scaler.Demo/OrderGenerator/Program.cs
Original file line number Diff line number Diff line change
Expand Up @@ -132,8 +132,11 @@ private static async Task CreateOrderAsync(Container container, string article)
private static async Task SetupAsync()
{
Console.WriteLine($"Creating database: {_cosmosDbConfig.DatabaseId}");
using var cosmosClient = _cosmosDbConfig.Connection.Contains("AccountKey")
? new CosmosClient(_cosmosDbConfig.Connection, new CosmosClientOptions { ConnectionMode = ConnectionMode.Gateway })
: new CosmosClient(_cosmosDbConfig.Connection, new DefaultAzureCredential(), new CosmosClientOptions { ConnectionMode = ConnectionMode.Direct });

Database database = await new CosmosClient(_cosmosDbConfig.Connection)
Database database = await cosmosClient
.CreateDatabaseIfNotExistsAsync(_cosmosDbConfig.DatabaseId);

Console.WriteLine($"Creating container: {_cosmosDbConfig.ContainerId} with throughput: {_cosmosDbConfig.ContainerThroughput} RU/s");
Expand All @@ -147,12 +150,14 @@ await database.CreateContainerIfNotExistsAsync(

private static async Task TeardownAsync()
{
var client = new CosmosClient(_cosmosDbConfig.Connection);
using var cosmosClient = _cosmosDbConfig.Connection.Contains("AccountKey")
? new CosmosClient(_cosmosDbConfig.Connection, new CosmosClientOptions { ConnectionMode = ConnectionMode.Gateway })
: new CosmosClient(_cosmosDbConfig.Connection, new DefaultAzureCredential(), new CosmosClientOptions { ConnectionMode = ConnectionMode.Direct });

try
{
Console.WriteLine($"Deleting database: {_cosmosDbConfig.DatabaseId}");
await client.GetDatabase(_cosmosDbConfig.DatabaseId).DeleteAsync();
await cosmosClient.GetDatabase(_cosmosDbConfig.DatabaseId).DeleteAsync();
}
catch (CosmosException)
{
Expand Down
4 changes: 2 additions & 2 deletions src/Scaler.Demo/OrderProcessor/Worker.cs
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ public override async Task StartAsync(CancellationToken cancellationToken)
? new CosmosClient(_cosmosDbConfig.Connection)
: new CosmosClient(_cosmosDbConfig.Connection, new DefaultAzureCredential());

Database leaseDatabase = await new CosmosClient(_cosmosDbConfig.LeaseConnection)
Database leaseDatabase = await cosmosClient
.CreateDatabaseIfNotExistsAsync(_cosmosDbConfig.LeaseDatabaseId, cancellationToken: cancellationToken);

Container leaseContainer = await leaseDatabase
Expand All @@ -42,7 +42,7 @@ public override async Task StartAsync(CancellationToken cancellationToken)
// Change feed processor instance name should be unique for each container application.
string instanceName = $"Instance-{Dns.GetHostName()}";

_processor = new CosmosClient(_cosmosDbConfig.Connection)
_processor = cosmosClient
.GetContainer(_cosmosDbConfig.DatabaseId, _cosmosDbConfig.ContainerId)
.GetChangeFeedProcessorBuilder<Order>(_cosmosDbConfig.ProcessorName, ProcessOrdersAsync)
.WithInstanceName(instanceName)
Expand Down
4 changes: 3 additions & 1 deletion src/Scaler.Tests/CosmosDbScalerServiceTests.cs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
using System;
using System.Threading.Tasks;
using Google.Protobuf.Collections;
using Microsoft.Extensions.Logging;
using Moq;
using Newtonsoft.Json;
using Xunit;
Expand All @@ -15,7 +16,8 @@ public class CosmosDbScalerServiceTests
public CosmosDbScalerServiceTests()
{
_metricProviderMock = new Mock<ICosmosDbMetricProvider>();
_cosmosDbScalerService = new CosmosDbScalerService(_metricProviderMock.Object);
var _loggerMock = new Mock<ILogger<CosmosDbScalerService>>();
_cosmosDbScalerService = new CosmosDbScalerService(_metricProviderMock.Object, _loggerMock.Object);
}

[Theory]
Expand Down
10 changes: 9 additions & 1 deletion src/Scaler/Services/CosmosDbMetricProvider.cs
Original file line number Diff line number Diff line change
Expand Up @@ -41,10 +41,18 @@ public async Task<long> GetPartitionCountAsync(ScalerMetadata scalerMetadata)
while (iterator.HasMoreResults)
{
FeedResponse<ChangeFeedProcessorState> states = await iterator.ReadNextAsync();
partitionCount += states.Where(state => state.EstimatedLag > 0).Count();

foreach (ChangeFeedProcessorState leaseState in states)
{
string host = leaseState.InstanceName == null ? $"not owned by any host currently" : $"owned by host {leaseState.InstanceName}";
_logger.LogInformation("Lease [{LeaseToken}] {host} reports {EstimatedLag} as estimated lag.", leaseState.LeaseToken, host, leaseState.EstimatedLag);

partitionCount += leaseState.EstimatedLag > 0 ? 1 : 0;
}
}
}

_logger.LogInformation("Returning active {partitionCount}", partitionCount);
return partitionCount;
}
catch (CosmosException exception)
Expand Down
8 changes: 7 additions & 1 deletion src/Scaler/Services/CosmosDbScalerService.cs
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,21 @@ namespace Keda.CosmosDb.Scaler
internal sealed class CosmosDbScalerService : ExternalScaler.ExternalScalerBase
{
private readonly ICosmosDbMetricProvider _metricProvider;
private readonly ILogger<CosmosDbScalerService> _logger;

public CosmosDbScalerService(ICosmosDbMetricProvider metricProvider)
public CosmosDbScalerService(ICosmosDbMetricProvider metricProvider, ILogger<CosmosDbScalerService> logger)
{
_metricProvider = metricProvider ?? throw new ArgumentNullException(nameof(metricProvider));
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
}

public override async Task<IsActiveResponse> IsActive(ScaledObjectRef request, ServerCallContext context)
{
var scalerMetadata = ScalerMetadata.Create(request);

bool isActive = (await _metricProvider.GetPartitionCountAsync(scalerMetadata)) > 0L;

_logger.LogInformation("Scaler is {status}", isActive ? "active" : "inactive");
return new IsActiveResponse { Result = isActive };
}

Expand All @@ -34,6 +38,7 @@ public override async Task<GetMetricsResponse> GetMetrics(GetMetricsRequest requ
MetricValue_ = await _metricProvider.GetPartitionCountAsync(scalerMetadata),
});

_logger.LogInformation("Returning metric value {value} for metric {metric}", response.MetricValues[0].MetricValue_, response.MetricValues[0].MetricName);
return response;
}

Expand All @@ -49,6 +54,7 @@ public override Task<GetMetricSpecResponse> GetMetricSpec(ScaledObjectRef reques
TargetSize = 1L,
});

_logger.LogInformation("Returning target size {size} for metric {metric}", response.MetricSpecs[0].TargetSize, response.MetricSpecs[0].MetricName);
return Task.FromResult(response);
}
}
Expand Down

0 comments on commit 3dc96e3

Please sign in to comment.