Skip to content

.NET Core library for asynchronous logging to Splunk using HTTP collector.

License

Notifications You must be signed in to change notification settings

agero-core/splunk-logger-async-core

Repository files navigation

Async Splunk Logger

NuGet Version NuGet Downloads

Async Splunk Logger is a .NET Core (>= v2.1) library for logging to Splunk using HTTP collector, asynchronously. It has in-memory queue and runs background threads to pick logs from queue and submit them to Splunk using Splunk Logger library.

The logging is implemented as a background task that uses hosted services introduced in .NET Core 2.1.

Usage:

Register LogProcessingBackgroundService in the app's dependency injection container with ConfigureServices. If you require multiple background threads for processing logs, register additional LogProcessingBackgroundService.

In .NET Core application:

var builder = new HostBuilder()
    .ConfigureServices((hostContext, services) =>
    {
        services.AddHostedService<LogProcessingBackgroundService>();  
        services.AddHostedService<LogProcessingBackgroundService>(); 
    })
    .Build();

builder.StartAsync();

In ASP.NET Core application:

public void ConfigureServices(IServiceCollection services)
{
    services.AddHostedService<LogProcessingBackgroundService>();
    services.AddHostedService<LogProcessingBackgroundService>();
}

Create instance:

IAsyncLogger logger = new AsyncLogger(
    collectorUri: new Uri("<Your Splunk Collector Url>"), 
    authorizationToken: "<Your Splunk Access Token>", 
    applicationName: "TestName", 
    applicationVersion: "1.2.3.4", 
    timeout: 3000);

Create log:

bool result = logger.Log(
    type: "TestInfo", 
    message: "Test message", 
    data: new { test1 = "test1", test2 = "test2" },
    correlationId: "1234567");	

This creates the following log in Splunk:

{  
   "type":"TestInfo",
   "name":"TestName",
   "version":"1.2.3.4",
   "message":"Test message",
   "system":{  
      "userName":"DomainName\\user",
      "userDomainName":"DomainName",
      "operatingSystem":"Unix 18.2.0.0",
      "is64BitOperatingSystem":true,
      "processorCount":4,
      "clrVersion":"4.0.30319.42000",
      "is64BitProcess":false,
      "machineName":"MACHINE-NAME",
      "localTime":"2017-08-16T14:43:07.7658829-04:00",
      "utcTime":"2017-08-16T18:43:07.7668831+00:00",
      "hostName":"MACHINE-NAME",
      "ipAddresses":[  
         "123.123.1.0"
      ]
   },
   "app":{  
      "test1":"test1",
      "test2":"test2"
   },
   "correlationId": "1234567"
}

Running Tests:

Create the json file logger-settings.json with the below configuration under the projects Agero.Core.SplunkLogger.Async.Core.Tests and Agero.Core.SplunkLogger.Async.Core.Web.

{
  "splunkCollectorUrl": "<Your Splunk Collector Url>",
  "authenticationToken": "<Your Splunk Access Token>"
}

About

.NET Core library for asynchronous logging to Splunk using HTTP collector.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages