Azure Functions supports the dependency injection (DI) software design pattern, which is a technique to achieve Inversion of Control (IoC) between classes and their dependencies, which means that the classes do not create or manage their dependencies, but receive them from an external source. This way, you can separate the concerns of your functions from the concerns of their dependencies, such as configuration, logging, data access, or business logic. You can also replace or mock your dependencies easily when testing or debugging your functions
Using dependency injection can help you write cleaner, more modular, and more testable code. For more information of how to leverage dependency injection to configure services lifetime, use options and settings for configurations in Azure Functions, see Dependency injection in Azure Functions.
- Use dependency injection in .NET Azure Functions to separate the concerns of your functions from the concerns of their dependencies, such as configuration, logging, data access, or business logic.
- Update a function app to use dependency injection.
- Use injected ILogger in your functions.
-
Before you can use dependency injection in your backend functionapp, you must install the following NuGet packages:
pushd src/backend dotnet add package Microsoft.Extensions.DependencyInjection --version 7.0.0 dotnet add package Microsoft.Azure.Functions.Extensions --version 1.1.0 popd
-
Create new file Startup.cs where you will register your services. To register services, create a method to configure and add the Healthz component to an IFunctionsHostBuilder instance. The Azure Functions host creates an instance of IFunctionsHostBuilder and passes it directly into your method.
using Microsoft.Azure.Functions.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection; [assembly: FunctionsStartup(typeof(backend.Startup))] namespace backend { public class Startup : FunctionsStartup { public override void Configure(IFunctionsHostBuilder builder) { builder.Services.AddSingleton<Healthz>(); } } }
-
Update Healthz.cs function to be non-static.
-
Run locally your backend application and validate is working as expected.
The host injects ILogger and ILoggerFactory services into constructors. However, by default these new logging filters are filtered out of the function logs. You need to modify the host.json file to opt-in to additional filters and categories.
-
Add a constructor that accepts <ILogger> log as a parameter to Healthz.cs. The Azure Functions host creates an instance of ILogger and passes it directly into your constructor.
using Microsoft.AspNetCore.Mvc; using Microsoft.Azure.WebJobs; using Microsoft.Azure.WebJobs.Extensions.Http; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Logging; namespace backend { public class Healthz { private readonly ILogger<Healthz> _log; public Healthz(ILogger<Healthz> log) { _log = log; } ...
-
Opt-in new additional filter in hosts.json by provising Healthz class namespace and name:
"logLevel": { // "default": "Information" "backend.Healthz": "Information" }
-
Run locally your backend application and validate logs are written to console while Healthz endpoint is called.
Name | Description |
---|---|
Use dependency injection in .NET Azure Functions | https://learn.microsoft.com/en-us/azure/azure-functions/functions-dotnet-dependency-injection |