From 589793841e6d1b5a97ad83c75d1b613c1331e867 Mon Sep 17 00:00:00 2001 From: Liam Pietralla Date: Fri, 11 Oct 2024 09:38:58 +1100 Subject: [PATCH] background service doc --- .vitepress/config.mts | 3 +- docs/dotnet/background-service.md | 57 +++++++++++++++++++++++++++++++ docs/dotnet/index.md | 1 + 3 files changed, 60 insertions(+), 1 deletion(-) create mode 100644 docs/dotnet/background-service.md diff --git a/.vitepress/config.mts b/.vitepress/config.mts index 46ff91a..f466c3b 100644 --- a/.vitepress/config.mts +++ b/.vitepress/config.mts @@ -24,6 +24,7 @@ export default defineConfig({ link: '/dotnet/', collapsed: true, items: [ + { text: 'Background Services', link: '/dotnet/background-service' }, { text: 'Blazor with an API', link: '/dotnet/blazor-with-api' }, { text: 'Database Seeding', link: '/dotnet/database-seed' }, { text: 'Dockerising Blazor', link: '/dotnet/dockerising-blazor' }, @@ -60,7 +61,7 @@ export default defineConfig({ link: '/docker/', collapsed: true, items: [ - { text: 'Docker Exec', link: '/docker/exec-into-contanainer' }, + { text: 'Docker Exec', link: '/docker/exec-into-container' }, ] }, { diff --git a/docs/dotnet/background-service.md b/docs/dotnet/background-service.md new file mode 100644 index 0000000..26b699c --- /dev/null +++ b/docs/dotnet/background-service.md @@ -0,0 +1,57 @@ +# Background Services + +Often in application you will want logic to execute in the background. This could be for a variety of reasons, such as: +* Processing data +* Sending emails +* Performing maintenance tasks +* Running scheduled jobs + +In .NET Core, you can create a background service by creating a class that inherits from the `BackgroundService` class. This class is part of the `Microsoft.Extensions.Hosting` namespace. + +::: warn + +The ability of a background service to run is dependent on the lifetime of the host. If the host is stopped, the background service will also stop. This means for software running in IIS you will need to ensure the site is always running. For this reason docker deployments are usually preferred + +::: + +## Creating a Background Service + +To create a background service, you need to create a class that inherits from the `BackgroundService` class. This class has a single method that you need to override, called `ExecuteAsync`. This method is called when the background service is started, and it should contain the logic that you want to run in the background. + +Here is an example of a simple background service that writes to the console every second: + +```csharp +using System; +using System.Threading; +using System.Threading.Tasks; +using Microsoft.Extensions.Hosting; + +namespace BackgroundServiceExample +{ + public class MyBackgroundService : BackgroundService + { + protected override async Task ExecuteAsync(CancellationToken stoppingToken) + { + while (!stoppingToken.IsCancellationRequested) + { + Console.WriteLine("Background service is running..."); + await Task.Delay(1000); + } + } + } +} +``` + +## Registering the Background Service + +The next step is to register the background service with the dependency injection container. You can do this in `Program.cs` when you are building the host. + +```csharp +// ... +builder.Services.AddHostedService(); +// ... +``` + +## Conclusion + +This is just a simple way to use background services, for more complex scenarios you may want to look at writing a console app that runs as a service which can be triggered by a scheduler or a message queue. This will also give you flexibility to run the service on a different machine or in a container and have separate configuration and so on. \ No newline at end of file diff --git a/docs/dotnet/index.md b/docs/dotnet/index.md index fd703c2..cc05f3e 100644 --- a/docs/dotnet/index.md +++ b/docs/dotnet/index.md @@ -1,5 +1,6 @@ # .NET Snippets and Musings +#### [Background Services](./background-service.md) #### [Blazor with an inbuilt API](./blazor-with-api.md) #### [Database Seeding](./database-seed.md) #### [Dockerising a Blazor Web App](./dockerising-blazor.md)