Merge pull request 'background service doc' (#3) from feat/background-service into main
Reviewed-on: #3
This commit is contained in:
		| @@ -24,6 +24,7 @@ export default defineConfig({ | |||||||
|         link: '/dotnet/', |         link: '/dotnet/', | ||||||
|         collapsed: true, |         collapsed: true, | ||||||
|         items: [ |         items: [ | ||||||
|  |           { text: 'Background Services', link: '/dotnet/background-service' }, | ||||||
|           { text: 'Blazor with an API', link: '/dotnet/blazor-with-api' }, |           { text: 'Blazor with an API', link: '/dotnet/blazor-with-api' }, | ||||||
|           { text: 'Database Seeding', link: '/dotnet/database-seed' }, |           { text: 'Database Seeding', link: '/dotnet/database-seed' }, | ||||||
|           { text: 'Dockerising Blazor', link: '/dotnet/dockerising-blazor' }, |           { text: 'Dockerising Blazor', link: '/dotnet/dockerising-blazor' }, | ||||||
| @@ -60,7 +61,7 @@ export default defineConfig({ | |||||||
|         link: '/docker/', |         link: '/docker/', | ||||||
|         collapsed: true, |         collapsed: true, | ||||||
|         items: [ |         items: [ | ||||||
|           { text: 'Docker Exec', link: '/docker/exec-into-contanainer' }, |           { text: 'Docker Exec', link: '/docker/exec-into-container' }, | ||||||
|         ] |         ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|   | |||||||
							
								
								
									
										57
									
								
								docs/dotnet/background-service.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								docs/dotnet/background-service.md
									
									
									
									
									
										Normal file
									
								
							| @@ -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<MyBackgroundService>(); | ||||||
|  | // ... | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## 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. | ||||||
| @@ -1,5 +1,6 @@ | |||||||
| # .NET Snippets and Musings | # .NET Snippets and Musings | ||||||
|  |  | ||||||
|  | #### [Background Services](./background-service.md) | ||||||
| #### [Blazor with an inbuilt API](./blazor-with-api.md) | #### [Blazor with an inbuilt API](./blazor-with-api.md) | ||||||
| #### [Database Seeding](./database-seed.md) | #### [Database Seeding](./database-seed.md) | ||||||
| #### [Dockerising a Blazor Web App](./dockerising-blazor.md) | #### [Dockerising a Blazor Web App](./dockerising-blazor.md) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user