This is a custom target for NLog that pushes log messages to Graylog using the Http input.
This library was influenced by EasyGelf
This library is packaged as a nuget package available here
Install-Package NLog.Targets.GraylogHttp
This library runs under netstandard 1.3 and fully supports .Net Core 2.1-3.1, .Net 5.0, and .Net Framework 4.5+
Add or modify your NLog Configuration to add the new target and Extension Assembly.
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<extensions>
<add assembly="NLog.Targets.GraylogHttp"/>
</extensions>
<targets>
<target name="graylog"
xsi:type="GraylogHttp"
facility="[FACILITY]"
graylogServer="[SERVER]"
graylogPort="[PORT]">
<!-- Location information. -->
<parameter name="source_method" layout="${callsite}" />
<parameter name="source_line" layout="${callsite-linenumber}" />
<parameter name="test_prop" layout="${event-context:item=test_prop}" />
</target>
</targets>
<rules>
<logger name="*" minlevel="Trace" appendTo="graylog"/>
</rules>
</nlog>
- graylogServer - REQUIRED - URI formatted address of your server (e.g. http://192.168.1.2, http://example.com, https://graylog.example.com:3030)
- graylogPort - OPTIONAL - server port, normally specified by Input in Graylog, Can also be specified in the server
- facility - OPTIONAL - variable could be used to identify your application, library, etc.
- useHttpClientFactory - OPTIONAL, only .NET Standard 2.0 - use IHttpClientFactory (loaded with ConfigurationItemFactory.Default.CreateInstance)
- httpClientName - OPTIONAL, only .NET Standard 2.0 - provide a named HttpClient (requires useHttpClientFactory true)
var logger = LogManager.GetCurrentClassLogger();
logger.Trace("String");
logger.Debug("String");
logger.Warn("String");
logger.Error("String");
logger.Fatal("String");
var logger = LogManager.GetCurrentClassLogger();
var e = new LogEventInfo(LogLevel.Fatal, "Test", "Test Message");
e.Properties["test_prop"] = "test property";
logger.Log(e);
var nlogCreateInstance = NLog.Config.ConfigurationItemFactory.Default.CreateInstance;
NLog.Config.ConfigurationItemFactory.Default.CreateInstance = (type) =>
{
return myServiceProvider.GetService(type) ?? nlogCreateInstance(type);
};
In order to receive logs in your Graylog server, make sure you create Input for your application mentioned in Getting Started guide under Collect Messages link.