Top Related Projects
Quick Overview
NLog is a flexible and free logging platform for various .NET platforms, including .NET Framework, .NET Core, and Xamarin. It helps developers easily add logging, tracing, and debugging capabilities to their applications, with support for structured and traditional logging.
Pros
- Highly configurable with extensive options for log targets, layouts, and filtering
- Supports both synchronous and asynchronous logging
- Offers good performance and low overhead
- Integrates well with popular .NET frameworks and libraries
Cons
- Configuration can be complex for advanced scenarios
- Documentation, while comprehensive, can be overwhelming for beginners
- Some users report occasional issues with log file locking
Code Examples
- Basic logging:
using NLog;
class Program
{
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
static void Main(string[] args)
{
Logger.Info("Hello, NLog!");
Logger.Error("This is an error message");
}
}
- Structured logging:
Logger.Info("User {Username} logged in from {IPAddress}", username, ipAddress);
- Conditional logging:
Logger.Trace("This is a trace message");
Logger.Debug("This is a debug message");
if (Logger.IsWarnEnabled)
{
Logger.Warn("This is a warning message");
}
- Exception logging:
try
{
// Some code that might throw an exception
}
catch (Exception ex)
{
Logger.Error(ex, "An error occurred while processing the request");
}
Getting Started
-
Install NLog package via NuGet:
Install-Package NLog
-
Create a basic NLog.config file in your project root:
<?xml version="1.0" encoding="utf-8" ?> <nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <targets> <target name="logfile" xsi:type="File" fileName="log.txt" /> <target name="console" xsi:type="Console" /> </targets> <rules> <logger name="*" minlevel="Info" writeTo="logfile,console" /> </rules> </nlog>
-
Add NLog to your code:
using NLog; class Program { private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); static void Main(string[] args) { Logger.Info("Application started"); // Your application code here } }
Competitor Comparisons
Simple .NET logging with fully-structured events
Pros of Serilog
- Structured logging with support for complex data types
- Easier configuration and setup, especially for beginners
- Better performance in high-throughput scenarios
Cons of Serilog
- Fewer built-in targets compared to NLog
- Less flexible configuration options for advanced scenarios
- Smaller ecosystem and community compared to NLog
Code Comparison
Serilog:
Log.Logger = new LoggerConfiguration()
.WriteTo.Console()
.CreateLogger();
Log.Information("Hello, {Name}!", name);
NLog:
var config = new LoggingConfiguration();
var consoleTarget = new ConsoleTarget("console");
config.AddRule(LogLevel.Info, LogLevel.Fatal, consoleTarget);
LogManager.Configuration = config;
logger.Info("Hello, {0}!", name);
Both NLog and Serilog are popular logging frameworks for .NET applications. Serilog excels in structured logging and ease of use, while NLog offers more flexibility and a wider range of built-in targets. Serilog's configuration is generally simpler, making it a good choice for beginners or projects that prioritize quick setup. NLog, on the other hand, provides more advanced configuration options and a larger ecosystem, which can be beneficial for complex logging requirements. Performance-wise, Serilog tends to have an edge in high-throughput scenarios. Ultimately, the choice between the two depends on specific project needs and developer preferences.
An addictive .NET IoC container
Pros of Autofac
- More flexible and powerful dependency injection capabilities
- Better support for advanced scenarios like circular dependencies
- Extensive integration with popular frameworks and libraries
Cons of Autofac
- Steeper learning curve for beginners
- Slightly more complex configuration compared to simpler DI containers
- Potential performance overhead in large-scale applications
Code Comparison
NLog (Logging):
private static Logger logger = LogManager.GetCurrentClassLogger();
logger.Info("This is an informational message");
logger.Error(exception, "An error occurred");
Autofac (Dependency Injection):
var builder = new ContainerBuilder();
builder.RegisterType<MyService>().As<IMyService>();
var container = builder.Build();
var service = container.Resolve<IMyService>();
While NLog focuses on logging functionality, Autofac is a dependency injection container. NLog provides a straightforward way to add logging to applications, while Autofac offers more advanced IoC capabilities for managing dependencies and improving application architecture.
NLog is generally easier to set up and use for basic logging needs, whereas Autofac requires more initial configuration but provides greater flexibility in managing object lifecycles and dependencies.
Both libraries are widely used in the .NET ecosystem and can be complementary in a single application, with NLog handling logging concerns and Autofac managing dependency injection.
Castle Windsor is a best of breed, mature Inversion of Control container available for .NET
Pros of Windsor
- Powerful dependency injection container with advanced features like interceptors and typed factories
- Supports various lifestyles for managing object lifecycles
- Integrates well with other Castle Project components
Cons of Windsor
- Steeper learning curve compared to simpler logging libraries
- May be overkill for projects that only need basic logging functionality
- Less frequent updates and smaller community compared to NLog
Code Comparison
Windsor (Dependency Injection):
container.Register(Component.For<ILogger>().ImplementedBy<ConsoleLogger>());
var logger = container.Resolve<ILogger>();
logger.Log("Hello, Windsor!");
NLog (Logging):
private static Logger logger = LogManager.GetCurrentClassLogger();
logger.Info("Hello, NLog!");
Summary
Windsor is a powerful dependency injection container, while NLog is a dedicated logging framework. Windsor offers more flexibility in managing object lifecycles and dependencies, but has a steeper learning curve. NLog is simpler to use for basic logging needs and has a larger community. The choice between them depends on whether you need a full-fledged IoC container or just a logging solution.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
NLog is a free logging platform for .NET with rich log routing and management capabilities. It makes it easy to produce and manage high-quality logs for your application regardless of its size or complexity.
It can process diagnostic messages emitted from any .NET language, augment them with contextual information, format them according to your preference and send them to one or more targets such as file or database.
Major and minor releases will be posted on project news.
Getting started
For the possible options in the config, check the Options list and API Reference
Having troubles? Check the troubleshooting guide
â¹ï¸ NLog 6.0 will support AOT
NLog 6.0 is now being prepared. See List of goals for NLog 6.0
NLog Packages
The NLog-nuget-package provides everything needed for doing file- and console-logging. But there are also multiple NLog extension packages, that provides additional target- and layout-output. See targets and layout renderers overview!
See Nuget/build status of all official packages here
Questions, bug reports or feature requests?
Issues with getting it working? Please check the troubleshooting guide before asking! With a clear error message, it's really easier to solve the issue!
Unclear how to configure NLog correctly of other questions? Please post questions on StackOverflow.
Do you have feature request or would you like to report a bug? Please post them on the issue list and follow these guidelines.
Frequently Asked Questions (FAQ)
See FAQ on the Wiki
Contributing
As the current NLog team is a small team, we cannot fix every bug or implement every feature on our own. So contributions are really appreciated!
If you like to start with a small task, then up-for-grabs are nice to start with.
Please note, we have a dev
and master
branch
master
is for pure bug fixes and targets NLog 5.xdev
targets NLog 6
A good way to get started (flow)
- Fork the NLog repos.
- Create a new branch in you current repos from the 'dev' branch. (critical bugfixes from 'master')
- 'Check out' the code with Git or GitHub Desktop
- Check contributing.md
- Push commits and create a Pull Request (PR) to NLog
Please note: bugfixes should target the master branch, others the dev branch (NLog 6)
License
NLog is open source software, licensed under the terms of BSD license. See LICENSE.txt for details.
How to build
Use Visual Studio 2019 and open the solution 'NLog.sln'.
For building in the cloud we use:
- AppVeyor for Windows- and Linux-builds
- SonarQube for code coverage
Trying to build your fork in the cloud? Check this how-to
Note: master points to NLog 5.x and dev to NLog 6
Top Related Projects
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot