Logging in .NET Core: A Comprehensive Guide

Logging in .NET Core: A Comprehensive Guide

07 Aug 2024
Beginner
4.3K Views
8 min read
Learn with an interactive course and practical hands-on labs

Free ASP.NET Core Online Course with Certificate - Start Now

Logging in .NET Core

Logging in .NET Core is all about gathering and documenting important data on the operation of your application. This includes keeping track of events such as warnings, errors, and general data, all of which can be very beneficial for monitoring and debugging.

In this Asp.Net Core Tutorial, We will explore more about Logging in .Net Core which will include What is DBContext? Logging in .net core example, Fundamentals of Logging in .NET Core. Let's see it one by one.

What is DbContext?

  • DbContext is the main class in the.NET Core domain that is in charge of communicating with the database via Entity Framework Core.
  • You can query and store data using it as a bridge between your domain or entity classes and the database.
  • It includes methods to control the lifespan of the entities and all the configurations required to connect to a database.

Different Types of Logs

Any application must include logging since it gives you insight into the program's behavior and helps with monitoring and debugging. An application may produce a variety of log types, including:

  • Debug Logs: Detailed data that is usually only useful for problem diagnosis.
  • Information Logs: Messages providing coarse-grained details about the application's progress.
  • Warning Logs: Dangerous circumstances that could cause problems if left unchecked.
  • Error logs: occurrences that might still permit the application to execute are recorded in the error logs.
  • Critical Logs: Severe error incidents resulting in the program being terminated.

Introduction to .NET Core Logging Levels and Their Hierarchy

Logging levels in.NET Core specify the level of severity of the messages that are logged. The levels are as follows, in ascending order of severity:

  • Trace: The most detailed data, usually utilized to identify issues.
  • Debug: Data that can be used to troubleshoot software during development.
  • Details: Broad operational occurrences that do not qualify as errors.
  • Alert: Draw attention to an odd or surprising application flow event.
  • Error: This shows where the current action is failing.
  • Important: Explain a system crash or unrecoverable program.

Configuring Logging in ASP.NET Core

1. Setting Up Logging with the ILoggerFactory Interface

A factory interface called ILoggerFactory is used to generate ILogger objects. It is employed for managing and configuring logging providers.

public void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)
{
    loggerFactory.AddConsole();
    loggerFactory.AddDebug();
}  

2. Registering Logging Providers (Console, File, Debug)

Multiple built-in logging providers, including Console, Debug, and File, are supported by ASP.NET Core. These providers can be registered in the Startup.cs or Program.cs file.
public void ConfigureServices(IServiceCollection services)
{
    services.AddLogging(builder =>
    {
        builder.AddConsole();
        builder.AddDebug();
        builder.AddFile("Logs/myDemoapp-{Date}.txt"); // Requires additional NuGet package
    });
}    

3. Determining the Minimum Log Level for Every Provider

In the appsettings.json file, you may specify the minimum log level for each provider separately.
{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft": "Warning",
      "System": "Warning"
    },
    "Console": {
      "LogLevel": {
        "Default": "Debug"
      }
    }
  }
}

Log Messages Writing

1. ILogger Interface: Writing Log Messages at Various Levels

Log messages are written using the ILogger interface. ILogger<T> can be injected into your classes to log messages at different levels.
public class HomeController : Controller
{
    private readonly ILogger _logger;

    public HomeController(ILogger logger)
    {
        _logger = logger;
    }

    public IActionResult Index()
    {
        _logger.LogInformation("This is information log.");
        _logger.LogWarning("This is warning log.");
        _logger.LogError("This is error log.");
        return View();
    }
}  

2. Adding Contextual Data (such as User IDs and Timestamps) to Log Messages

More context on the state and behavior of the program can be found in log messages.
public void LogWithContext(ILogger logger)
{
    using (logger.BeginScope("User ID: {UserId}", 23456))
    {
        logger.LogInformation("User-specific information.");
    }
}    

3. Organizing Log Messages to Make Them Readable

Debugging may be made much easier with readable log messages. When formatting log messages, use structured logging.
_logger.LogInformation("Order {OrderId} created successfully at {Timestamp}.", orderId, DateTime.Now); 

Consuming Logs

  • It effectively involves setting up a system where logs are collected, aggregated, and analyzed.
  • Tools such as Elasticsearch, Kibana, Application Insights, and Serilog are used to integrate for these purposes.

Selecting the Appropriate Log Level in Various Circumstances

  • Use trace/debug only for debugging and development; do not use it in production.
  • Information: This is used to record the application's overall flow.
  • Use only in the event of unusual or unexpected occurrences that won't force the program to terminate.
  • Error: This log is used to record errors that impede the continuation of the present task.
  • Critical: For serious mistakes that result in the application crashing, use.

Example of Logging in .NET Core

Here's a simple example of setting up and utilizing logging in an application for ASP.NET Core

Example

public class Program
{
    public static void Main(string[] args)
    {
        CreateHostBuilder(args).Build().Run();
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .ConfigureLogging(logging =>
            {
                logging.ClearProviders();
                logging.AddConsole();
                logging.AddDebug();
                logging.AddFile("Logs/myapp-{Date}.txt");
                logging.SetMinimumLevel(LogLevel.Information);
            })
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup();
            });
}

public class HomeController : Controller
{
    private readonly ILogger _logger;

    public HomeController(ILogger logger)
    {
        _logger = logger;
    }

    public IActionResult Index()
    {
        _logger.LogInformation("Accessed Index page at {Timestamp}.", DateTime.Now);
        return View();
    }
}   
Conclusion
You can gain great performance of your application by appropriately configuring and using logging, which will help with maintenance and troubleshooting. I hope you enjoyed learning this article. Your valuable feedback or comments about this article are always welcome. Consider our .NET Certification Training to learn .net from scratch. You can also learn about the ASP.NET Core Course to gain a better understanding of ASP.NET core concepts.

FAQs

Logging is the process of recording events in software as they happen in real-time, along with other information such as the infrastructure details, time taken to execute, etc.

 It helps debug issues, monitor the application's health, and understand user behavior. 

C:\ProgramData\Contrast\dotnet-core\ on Windows or /var/tmp/contrast/dotnet-core/ on Linux, 

Take our Aspnet skill challenge to evaluate yourself!

In less than 5 minutes, with our skill challenge, you can identify your knowledge gaps and strengths in a given skill.

GET FREE CHALLENGE

Share Article
About Author
Shailendra Chauhan (Microsoft MVP, Founder & CEO at ScholarHat)

Shailendra Chauhan, Founder and CEO of ScholarHat by DotNetTricks, is a renowned expert in System Design, Software Architecture, Azure Cloud, .NET, Angular, React, Node.js, Microservices, DevOps, and Cross-Platform Mobile App Development. His skill set extends into emerging fields like Data Science, Python, Azure AI/ML, and Generative AI, making him a well-rounded expert who bridges traditional development frameworks with cutting-edge advancements. Recognized as a Microsoft Most Valuable Professional (MVP) for an impressive 9 consecutive years (2016–2024), he has consistently demonstrated excellence in delivering impactful solutions and inspiring learners.

Shailendra’s unique, hands-on training programs and bestselling books have empowered thousands of professionals to excel in their careers and crack tough interviews. A visionary leader, he continues to revolutionize technology education with his innovative approach.
Accept cookies & close this