DEV Community

Cover image for Understanding .NET Core Service Lifetimes: A Beginner's Guide
Dewa Mahendra
Dewa Mahendra

Posted on • Updated on

Understanding .NET Core Service Lifetimes: A Beginner's Guide

When building applications with .NET Core, managing the lifecycle of your services is crucial for maintaining a clean and efficient codebase. .NET Core's dependency injection (DI) framework provides three types of service lifetimes: Singleton, Scoped, and Transient. Understanding these lifetimes helps you control how services are created and managed throughout your application. Let's explore each service lifetime in detail.


What is Dependency Injection?

Before diving into service lifetimes, let's briefly understand dependency injection (DI). DI is a design pattern that allows an object to receive its dependencies from an external source rather than creating them itself. This approach promotes loose coupling and makes your code more modular, testable, and maintainable.
In .NET Core, DI is built-in and services are registered in the Startup class, typically in the ConfigureServicesmethod.


Service Lifetimes in .NET Core

.NET Core defines three service lifetimes: Singleton, Scoped, and Transient. Each has its own use case and behavior.

1. Singleton
A Singleton service is created once and shared across the entire application lifetime. It is ideal for services that maintain state or need to be reused globally. Here’s how it works:

  • Lifetime: The service is created once and reused for every
    subsequent request.

  • Use Case: Ideal for stateful services, configuration settings, or
    services that are expensive to create.

Example:

public void ConfigureServices(IServiceCollection services)
{
    services.AddSingleton<IMySingletonService, MySingletonService>();
}
Enter fullscreen mode Exit fullscreen mode

In this example, MySingletonServiceis registered as a singleton, ensuring only one instance is created and shared.

2. Scoped
A Scoped service is created once per client request. This is useful for services that should be unique per request but reused within that request. Here’s how it works:

  • Lifetime: The service is created once per HTTP request and shared
    within that request.

  • Use Case: Ideal for database contexts or unit of work patterns
    where a new instance is needed per request.

Example:

public void ConfigureServices(IServiceCollection services)
{
    services.AddScoped<IMyScopedService, MyScopedService>();
}
Enter fullscreen mode Exit fullscreen mode

In this example, MyScopedServiceis registered as scoped, ensuring a new instance is created for each request.

3. Transient
A Transient service is created each time it is requested. This is useful for lightweight, stateless services. Here’s how it works:

  • Lifetime: A new instance is created every time the service is
    requested.

  • Use Case: Ideal for stateless services, utilities, or lightweight
    operations.

Example:

public void ConfigureServices(IServiceCollection services)
{
    services.AddTransient<IMyTransientService, MyTransientService>();
}
Enter fullscreen mode Exit fullscreen mode

In this example, MyTransientServiceis registered as transient, ensuring a new instance is created each time it’s needed.


Choosing the Right Service Lifetime

Choosing the appropriate service lifetime depends on your specific requirements:

  • Singleton: Use for shared, stateful services or expensive-to-create objects that need to be reused.
  • Scoped: Use for per-request services, like database contexts, to ensure a new instance is used within each request.
  • Transient: Use for lightweight, stateless services that can be created frequently without significant overhead.

Conclusion

Understanding .NET Core service lifetimes is crucial for building efficient and scalable applications. By choosing the right service lifetime, you can ensure your services are created and managed appropriately, leading to better performance and maintainability. Whether you need a singleton for shared state, scoped for per-request instances, or transient for lightweight tasks, .NET Core’s DI framework provides the flexibility to meet your needs.

Top comments (0)