.NET SDK workload sets
The workload sets feature provides a version number that represents a group of .NET SDK workloads. The install, update, and restore commands use this number in workload-set update mode to provide the following benefits:
- You control the cadence of change for installed workload versions. The alternative mode of operation without using workload sets is called loose manifests update mode. In this mode, workloads are updated automatically as new versions of individual workloads are released onto any configured NuGet feeds. In
workload-set
update mode, workloads stay at a specific workload-set version until you explicitly change that version. - You can install and update a combination of workload versions that ship at the same time and are known to work together.
- You can ensure that everyone on your team is always working on the same workload versions.
- You don't have to use a rollback file to specify what workload version you want to be on.
Here are some ways you can use workload sets:
- "Pin" the
install
command to a specific workload-set version. - Update installed workloads to the latest available workload-set version.
- Update to a specified workload-set version.
- Specify the workload-set version in global.json.
- Check your current update mode and workload-set version.
And you can still choose to install, update, or restore to the latest version of each individual workload, ignoring workload sets.
Prerequisites
.NET 8.0.400 SDK or later.
In 8.0.400 SDK, the
dotnet workload
commands are in workload-set update mode only when it's explicitly selected.
"Pin" the install command
A dotnet workload install
command with the --version
option "pins" the install
command in workload-set
update mode with the specified workload-set version.
The command no longer automatically installs the newest workload based on loose manifests.
To "pin" the install
command:
Choose a workload-set version. For example,
9.0.100-preview.7.24414.1
.Choose a workload. For example,
aspire
.-
dotnet workload install aspire --version 9.0.100-preview.7.24414.1
When this command runs:
- It selects
workload-set
update mode if that isn't already selected. - It gets the workload set that has the specified version.
- From the workload set, it gets the manifest version of the specified workload.
- It installs the manifest version of the workload.
- It stays in
workload-set
update mode when it's done.
- It selects
Choose another workload to install, such as
maui-ios
.-
dotnet workload install maui-ios
This command installs the
maui-ios
workload using the workload version from the workload-set version9.0.100-preview.7.24414.1
, since the precedinginstall
command example pinned that workload set.
Using --version
with either install
or update
pins install
to the specified version, but update
is only configured for workload-set
update mode, not to a specific workload-set version. If you then run dotnet workload update
without the --version
option, the update
command:
- Updates workloads to the latest available workload-set version.
- "Unpins" the
install
command. - Stays in
workload-set
update mode.
Update using latest workload set
To update installed workloads to the latest workload-set version available on the configured feeds, run the following commands:
-
dotnet workload config --update-mode workload-set
The preceding command is necessary only if you are currently in manifests update mode. If you don't know, check the current update mode.
-
dotnet workload update
In
workload-set
update mode, this command updates workloads to the latest workload-set version, unless you have specified the workload-set version in global.json.
Update to a workload-set version
To specify a workload-set version to update to when you're not specifying it in global.json, use the --version
option of the update
command:
Choose a workload-set version. For example,
8.0.400
.-
dotnet workload update --version 8.0.400
workload-set
update mode will be selected if it wasn't already selected.
Use global.json for the workload-set version
To use a global.json
file to specify the workload-set version for a repository:
Choose a workload-set version. For example,
9.0.100-preview.7.24414.1
.Create a
global.json
file that looks like the following example:{ "sdk": { "workloadVersion": "9.0.100-preview.7.24414.1" } }
With the current directory in the same repository and the CLI in workload-set
update mode, the install
, update
, and restore
commands install workloads for the specified workload-set version. If you don't have a global.json file and you're in workload-set
update mode, the restore
command installs the workload-set version that was established when you switched from manifests update mode to workload-set
update mode.
If you have a workload-set version in the global.json file, the workload commands are in workload-set
mode even if you haven't run the config
command or used --version
. The global.json file overrides those.
To use the --version
option in that case, run the command outside of the path containing the global.json file.
If you don't specify the workload-set version in global.json, you can use the --version
option with the restore
comand. In that case, the restore
command selects workload-set
update mode before it restores workloads to the specified workload-set version.
In manifests update mode, restore
installs or updates workloads to the latest version of each individual workload.
Check the update mode and version
To see the current update mode, run the config
command with the --update-mode
option without an argument. The mode is either workload-set
or manifests
. For example:
dotnet workload config --update-mode
workload-set
To see the current workload-set version, run dotnet workload --version
. If a workload set is installed, you see a version such as 9.0.100-preview.7.24414.1 or 8.0.402. For example:
dotnet workload --version
9.0.100-preview.7.24414.1
In manifests mode, or if the workload-set version isn't established yet after switching to workload-set
update mode, you see a version in the form of <feature band>-manifests.<hash>
. For example:
dotnet workload --version
9.0.100-manifests.cf958b56
Choose a workload-set version
Workload sets are published to nuget.org with each release of the .NET SDK, under the package ID Microsoft.NET.Workloads.<feature band>
. For a stable version of the SDK, there is always a matching workload-set version. So 8.0.400 SDK can install an 8.0.400 workload set, and 401 can install a 401 set. In general, we recommend that you install the matching workload set for a stable SDK.
For preview releases, find the corresponding workload-set version in the package's README tab. For example, see the README tab for the .NET 9 Preview 7 package.
In the future, you'll be able to see a list of workload-set versions and what they contain.
Ignore workload sets
To install, or update to, the latest version of each individual workload available on the configured feeds, select and use manifests update mode by running the workload config
command:
dotnet workload config --update-mode manifests
In .NET 8.0.4xx SDK, manifests mode is the default. In this version, you need to select manifests mode explicitly only if you explicitly selected workload-set
update mode previously.