Skip to main content

ASP.NET Core - IHostingStartup

ASP.NET Core 2.0 introduces a new interface called IHostingStartup. Through this interface you can manipulate the process of building the web host outside your ASP.NET Core project. Just by including the DLL, you can hook into the configuration pipeline.

Implementing IHostingStartup

Let’s start by implementing this interface:

  • Create a new .NET Standard Class Library
  • Reference the Microsoft.AspNetCore.Hosting.Abstractions package. This package contains the IHostingStartup interface.
  • Create a new class and implement this interface. Just as an example we add a Console.Writeline to the Configure method:

Make the magic work

Unfortunately we are not there yet and we have to take some extra steps:

  • First add the HostingStartup attribute to your class library:

[assembly: HostingStartup(typeof(ClassLibrary1.MyCustomStartup))]

  • Now the ASP.NET Core runtime has the necessary information where to find our startup inside the DLL.
  • Next step is to setup an environment variable to let the runtime scan the dependency:
    • Right click on your ASP.NET Core project and go to Properties
    • Go to the Debug tab and add the following environment variable:
      • ASPNETCORE_HOSTINGSTARTUPASSEMBLIES=ClassLibrary1
    • The environment variable is a semicolon-delimited list of assemblies.
  • As a last step we have to activate the assembly. Probably the easiest way is by adding a reference, but using the Runtime store is also possible

If we now run our application, we see that the IHostingStartup Configure method is invoked:

More information: https://docs.microsoft.com/en-us/aspnet/core/fundamentals/host/platform-specific-configuration?view=aspnetcore-2.2

Popular posts from this blog

.NET 8–Keyed/Named Services

A feature that a lot of IoC container libraries support but that was missing in the default DI container provided by Microsoft is the support for Keyed or Named Services. This feature allows you to register the same type multiple times using different names, allowing you to resolve a specific instance based on the circumstances. Although there is some controversy if supporting this feature is a good idea or not, it certainly can be handy. To support this feature a new interface IKeyedServiceProvider got introduced in .NET 8 providing 2 new methods on our ServiceProvider instance: object? GetKeyedService(Type serviceType, object? serviceKey); object GetRequiredKeyedService(Type serviceType, object? serviceKey); To use it, we need to register our service using one of the new extension methods: Resolving the service can be done either through the FromKeyedServices attribute: or by injecting the IKeyedServiceProvider interface and calling the GetRequiredKeyedServic...

Azure DevOps/ GitHub emoji

I’m really bad at remembering emoji’s. So here is cheat sheet with all emoji’s that can be used in tools that support the github emoji markdown markup: All credits go to rcaviers who created this list.

Kubernetes–Limit your environmental impact

Reducing the carbon footprint and CO2 emission of our (cloud) workloads, is a responsibility of all of us. If you are running a Kubernetes cluster, have a look at Kube-Green . kube-green is a simple Kubernetes operator that automatically shuts down (some of) your pods when you don't need them. A single pod produces about 11 Kg CO2eq per year( here the calculation). Reason enough to give it a try! Installing kube-green in your cluster The easiest way to install the operator in your cluster is through kubectl. We first need to install a cert-manager: kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.14.5/cert-manager.yaml Remark: Wait a minute before you continue as it can take some time before the cert-manager is up & running inside your cluster. Now we can install the kube-green operator: kubectl apply -f https://github.com/kube-green/kube-green/releases/latest/download/kube-green.yaml Now in the namespace where we want t...