9.9 KiB
title | author | description | monikerRange | ms.author | ms.custom | ms.date | uid |
---|---|---|---|---|---|---|---|
Enhance an app from an external assembly in ASP.NET Core with IHostingStartup | guardrex | Discover how to enhance an ASP.NET Core app from an external assembly using an IHostingStartup implementation. | >= aspnetcore-2.0 | riande | mvc | 12/07/2017 | fundamentals/configuration/platform-specific-configuration |
Enhance an app from an external assembly in ASP.NET Core with IHostingStartup
By Luke Latham
An IHostingStartup implementation allows adding enhancements to an app at startup from an external assembly outside of the app's Startup
class. For example, an external tooling library can use an IHostingStartup
implementation to provide additional configuration providers or services to an app. IHostingStartup
is available in ASP.NET Core 2.0 and later.
View or download sample code (how to download)
Discover loaded hosting startup assemblies
To discover hosting startup assemblies loaded by the app or by libraries, enable logging and check the application logs. Errors that occur when loading assemblies are logged. Loaded hosting startup assemblies are logged at the Debug level, and all errors are logged.
The sample app reads the HostingStartupAssembliesKey into a string
array and displays the result in the app's Index page:
Disable automatic loading of hosting startup assemblies
There are two ways to disable the automatic loading of hosting startup assemblies:
- Set the Prevent Hosting Startup host configuration setting.
- Set the
ASPNETCORE_PREVENTHOSTINGSTARTUP
environment variable.
When either the host setting or the environment variable is set to true
or 1
, hosting startup assemblies aren't automatically loaded. If both are set, the host setting controls the behavior.
Disabling hosting startup assemblies using the host setting or environment variable disables them globally and may disable several characteristics of an app. It isn't currently possible to selectively disable a hosting startup assembly added by a library unless the library offers its own configuration option. A future release will offer the ability to selectively disable hosting startup assemblies (see GitHub issue aspnet/Hosting #1243).
Implement IHostingStartup
Create the assembly
An IHostingStartup
enhancement is deployed as an assembly based on a console app without an entry point. The assembly references the Microsoft.AspNetCore.Hosting.Abstractions package:
A HostingStartup attribute identifies a class as an implementation of IHostingStartup
for loading and execution when building the IWebHost. In the following example, the namespace is StartupEnhancement
, and the class is StartupEnhancementHostingStartup
:
A class implements IHostingStartup
. The class's Configure method uses an IWebHostBuilder to add enhancements to an app. IHostingStartup.Configure
in the hosting startup assembly is called by the runtime before Startup.Configure
in user code, which allows user code to overwrite any configruation provided by the hosting startup assembly.
When building an IHostingStartup
project, the dependencies file (*.deps.json) sets the runtime
location of the assembly to the bin folder:
Only part of the file is shown. The assembly name in the example is StartupEnhancement
.
Update the dependencies file
The runtime location is specified in the *.deps.json file. To active the enhancement, the runtime
element must specify the location of the enhancement's runtime assembly. Prefix the runtime
location with lib/<TARGET_FRAMEWORK_MONIKER>/
:
In the sample app, modification of the *.deps.json file is performed by a PowerShell script. The PowerShell script is automatically triggered by a build target in the project file.
Enhancement activation
Place the assembly file
The IHostingStartup
implementation's assembly file must be bin-deployed in the app or placed in the runtime store:
For per-user use, place the assembly in the user profile's runtime store at:
<DRIVE>\Users\<USER>\.dotnet\store\x64\<TARGET_FRAMEWORK_MONIKER>\<ENHANCEMENT_ASSEMBLY_NAME>\<ENHANCEMENT_VERSION>\lib\<TARGET_FRAMEWORK_MONIKER>\
For global use, place the assembly in the .NET Core installation's runtime store:
<DRIVE>\Program Files\dotnet\store\x64\<TARGET_FRAMEWORK_MONIKER>\<ENHANCEMENT_ASSEMBLY_NAME>\<ENHANCEMENT_VERSION>\lib\<TARGET_FRAMEWORK_MONIKER>\
When deploying the assembly to the runtime store, the symbols file may be deployed as well but isn't required for the enhancement to work.
Place the dependencies file
The implementation's *.deps.json file must be in an accessible location.
For per-user use, place the file in the additonalDeps
folder of the user profile's .dotnet
settings:
<DRIVE>\Users\<USER>\.dotnet\x64\additionalDeps\<ENHANCEMENT_ASSEMBLY_NAME>\shared\Microsoft.NETCore.App\<SHARED_FRAMEWORK_VERSION>\
For global use, place the file in the additonalDeps
folder of the .NET Core installation:
<DRIVE>\Program Files\dotnet\additionalDeps\<ENHANCEMENT_ASSEMBLY_NAME>\shared\Microsoft.NETCore.App\<SHARED_FRAMEWORK_VERSION>\
The shared framework version reflects the version of the shared runtime that the target app uses. The shared runtime is shown in the *.runtimeconfig.json file. In the sample app, the shared runtime is specified in the HostingStartupSample.runtimeconfig.json file.
Set environment variables
Set the following environment variables in the context of the app that uses the enhancement.
ASPNETCORE_HOSTINGSTARTUPASSEMBLIES
Only hosting startup assemblies are scanned for the HostingStartupAttribute
. The assembly name of the implementation is provided in this environment variable. The sample app sets this value to StartupDiagnostics
.
The value can also be set using the Hosting Startup Assemblies host configuration setting.
When multiple hosting startup assembles are present, their Configure methods are executed in the order that the assemblies are listed.
DOTNET_ADDITIONAL_DEPS
The location of the implementation's *.deps.json file.
If the file is placed in the user profile's .dotnet folder for per-user use:
<DRIVE>\Users\<USER>\.dotnet\x64\additionalDeps\
If the file is placed in the .NET Core installation for global use, provide the full path to the file:
<DRIVE>\Program Files\dotnet\additionalDeps\<ENHANCEMENT_ASSEMBLY_NAME>\shared\Microsoft.NETCore.App\<SHARED_FRAMEWORK_VERSION>\<ENHANCEMENT_ASSEMBLY_NAME>.deps.json
The sample app sets this value to:
%UserProfile%\.dotnet\x64\additionalDeps\StartupDiagnostics\
For examples of how to set environment variables for various operating systems, see Use multiple environments.
Sample app
The sample app (how to download) uses IHostingStartup
to create a diagnostics tool. The tool adds two middlewares to the app at startup that provide diagnostic information:
- Registered services
- Address: scheme, host, path base, path, query string
- Connection: remote IP, remote port, local IP, local port, client certificate
- Request headers
- Environment variables
To run the sample:
- The Startup Diagnostic project uses PowerShell to modify its StartupDiagnostics.deps.json file. PowerShell is installed by default on Windows OS starting with Windows 7 SP1 and Windows Server 2008 R2 SP1. To obtain PowerShell on other platforms, see Installing Windows PowerShell.
- Build the Startup Diagnostic project. A build target in the project file:
- Moves the assembly and symbols files to the user profile's runtime store.
- Triggers the PowerShell script to modify the StartupDiagnostics.deps.json file.
- Moves the StartupDiagnostics.deps.json file to the user profile's
additionalDeps
folder.
- Set the environment variables:
ASPNETCORE_HOSTINGSTARTUPASSEMBLIES
:StartupDiagnostics
DOTNET_ADDITIONAL_DEPS
:%UserProfile%\.dotnet\x64\additionalDeps\StartupDiagnostics\
- Run the sample app.
- Request the
/services
endpoint to see the app's registered services. Request the/diag
endpoint to see the diagnostic information.