AspNetCore.Docs/aspnetcore/blazor/host-and-deploy/configure-linker.md

123 lines
5.2 KiB
Markdown
Raw Normal View History

2019-02-02 01:49:02 +08:00
---
title: Configure the Linker for ASP.NET Core Blazor
2019-02-02 01:49:02 +08:00
author: guardrex
description: Learn how to control the Intermediate Language (IL) Linker when building a Blazor app.
2021-08-07 07:43:19 +08:00
monikerRange: '= aspnetcore-3.1'
2019-02-02 01:49:02 +08:00
ms.author: riande
ms.custom: mvc
2024-11-18 21:14:57 +08:00
ms.date: 11/12/2024
2020-06-19 21:24:40 +08:00
uid: blazor/host-and-deploy/configure-linker
2019-02-02 01:49:02 +08:00
---
# Configure the Linker for ASP.NET Core Blazor
2019-02-02 01:49:02 +08:00
2022-03-15 17:53:00 +08:00
This article explains how to control the Intermediate Language (IL) Linker when building a Blazor app.
Blazor WebAssembly performs [Intermediate Language (IL)](/dotnet/standard/glossary#il) linking during a build to trim unnecessary IL from the app's output assemblies. The linker is disabled when building in Debug configuration. Apps must build in Release configuration to enable the linker. We recommend building in Release when deploying your Blazor WebAssembly apps.
2019-02-02 01:49:02 +08:00
Linking an app optimizes for size but may have detrimental effects. Apps that use [reflection](/dotnet/csharp/advanced-topics/reflection-and-attributes/) or related dynamic features may break when trimmed because the linker doesn't know about this dynamic behavior and can't determine in general which types are required for reflection at runtime. To trim such apps, the linker must be informed about any types required by reflection in the code and in packages or frameworks that the app depends on.
2019-02-02 01:49:02 +08:00
To ensure the trimmed app works correctly once deployed, it's important to test Release builds of the app frequently while developing.
Linking for Blazor apps can be configured using these MSBuild features:
* Configure linking globally with a [MSBuild property](#control-linking-with-an-msbuild-property).
* Control linking on a per-assembly basis with a [configuration file](#control-linking-with-a-configuration-file).
2019-02-02 01:49:02 +08:00
## Control linking with an MSBuild property
2019-02-02 01:49:02 +08:00
Linking is enabled when an app is built in `Release` configuration. To change this, configure the `BlazorWebAssemblyEnableLinking` MSBuild property in the project file:
2019-02-02 01:49:02 +08:00
```xml
<PropertyGroup>
<BlazorWebAssemblyEnableLinking>false</BlazorWebAssemblyEnableLinking>
2019-02-02 01:49:02 +08:00
</PropertyGroup>
```
## Control linking with a configuration file
Control linking on a per-assembly basis by providing an XML configuration file and specifying the file as a MSBuild item in the project file:
2019-02-02 01:49:02 +08:00
```xml
<ItemGroup>
<BlazorLinkerDescriptor Include="LinkerConfig.xml" />
</ItemGroup>
```
2020-06-23 19:34:40 +08:00
`LinkerConfig.xml`:
2019-02-02 01:49:02 +08:00
```xml
<?xml version="1.0" encoding="UTF-8" ?>
<!--
This file specifies which parts of the BCL or Blazor packages must not be
stripped by the IL Linker even if they aren't referenced by user code.
-->
<linker>
<assembly fullname="mscorlib">
<!--
Preserve the methods in WasmRuntime because its methods are called by
JavaScript client-side code to implement timers.
Fixes: https://github.com/dotnet/blazor/issues/239
2019-02-02 01:49:02 +08:00
-->
<type fullname="System.Threading.WasmRuntime" />
</assembly>
<assembly fullname="System.Core">
<!--
System.Linq.Expressions* is required by Json.NET and any
expression.Compile caller. The assembly isn't stripped.
-->
<type fullname="System.Linq.Expressions*" />
</assembly>
<!--
In this example, the app's entry point assembly is listed. The assembly
isn't stripped by the IL Linker.
-->
<assembly fullname="MyCoolBlazorApp" />
</linker>
```
For more information and examples, see [Data Formats (`dotnet/runtime` GitHub repository)](https://github.com/dotnet/runtime/blob/main/docs/tools/illink/data-formats.md).
## Add an XML linker configuration file to a library
To configure the linker for a specific library, add an XML linker configuration file into the library as an embedded resource. The embedded resource must have the same name as the assembly.
2020-06-23 19:34:40 +08:00
In the following example, the `LinkerConfig.xml` file is specified as an embedded resource that has the same name as the library's assembly:
```xml
<ItemGroup>
<EmbeddedResource Include="LinkerConfig.xml">
<LogicalName>$(MSBuildProjectName).xml</LogicalName>
</EmbeddedResource>
</ItemGroup>
```
2019-11-21 23:35:46 +08:00
### Configure the linker for internationalization
2024-09-12 01:48:54 +08:00
Blazor's linker configuration for Blazor WebAssembly apps strips out internationalization information except for locales explicitly requested. Removing these assemblies minimizes the app's size.
2019-11-21 23:35:46 +08:00
To control which I18N assemblies are retained, set the `<BlazorWebAssemblyI18NAssemblies>` MSBuild property in the project file:
2019-11-21 23:35:46 +08:00
```xml
<PropertyGroup>
<BlazorWebAssemblyI18NAssemblies>{all|none|REGION1,REGION2,...}</BlazorWebAssemblyI18NAssemblies>
2019-11-21 23:35:46 +08:00
</PropertyGroup>
```
| Region Value | Mono region assembly |
| ---------------- | ----------------------- |
| `all` | All assemblies included |
2020-06-23 19:34:40 +08:00
| `cjk` | `I18N.CJK.dll` |
| `mideast` | `I18N.MidEast.dll` |
2019-11-21 23:35:46 +08:00
| `none` (default) | None |
2020-06-23 19:34:40 +08:00
| `other` | `I18N.Other.dll` |
| `rare` | `I18N.Rare.dll` |
| `west` | `I18N.West.dll` |
2019-11-21 23:35:46 +08:00
Use a comma to separate multiple values (for example, `mideast,west`).
For more information, see [I18N: Pnetlib Internationalization Framework Library (mono/mono GitHub repository)](https://github.com/mono/mono/tree/main/mcs/class/I18N).
## Additional resources
* <xref:blazor/performance#intermediate-language-il-linking>