Skip to content

Commit

Permalink
Add new proposal for workload set versions, and some garbage collecti…
Browse files Browse the repository at this point in the history
…on details
  • Loading branch information
dsplaisted committed Jan 8, 2024
1 parent bf382a0 commit e3dd128
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 0 deletions.
5 changes: 5 additions & 0 deletions accepted/2023/simplify-workload-versioning-implementation.md
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,10 @@ When installing a workload, it is installed only for the active workload set ver

### Workload set / workload manifest garbage collection

- Garbage collection occurs within the scope of a feature band, reference counts are used across feature bands.
- Baseline workload sets should not be garbage collected. They will be identified by convention as they should have a `baseline.workloadset.json` file
- Manifests installed with the SDK need to have feature band reference counts to prevent other feature bands from garbage collecting them. This should happen normally for MSI-based installs, but file-based installs will need to ship with the appropriate marker files with the path `metadata/workloads/InstalledManifests/v1/<manifestId>/<manifestVersion>/<manifestFeatureBand>/<SDKFeatureBand>`.


### Workload updates

Expand All @@ -122,3 +126,4 @@ Because of this, we will change CLI workload commands such as `dotnet workload i
### Telemetry

We would like to better understand whether people are using SDKs installed by Visual Studio, standalone installs, or both. We will add this information to the telemetry that we send. To support this we will update the .NET SDK MSI to conditionally include a `.vs` or `.standalone` file in the SDK folder to identify how it was installed.

16 changes: 16 additions & 0 deletions accepted/2023/simplify-workload-versioning.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,22 @@ Currently, we use a 3 part version number for the .NET SDK, for example 8.0.100.

We will create the concept of a "workload set" which has a version number that encapsulates all the workload manifest versions that are released together. A workload set is essentially a mapping from the workload set version to the different versions for each workload manifest. For public releases, the workload set version will use the same version number as the .NET SDK. For example, when .NET SDK 8.0.101 releases, there will be a corresponding workload set version 8.0.101 that corresponds to the versions of the workloads that were released together with that .NET SDK.

## Interim workload set versions

For workload sets released between releases of the .NET SDK, we will use 4-part version numbers. For example, workload set 8.0.203 would be released together with .NET SDK 8.0.203. If we want to release another workload set before the 8.0.204 SDK release, then we can designate that workload set as 8.0.203.1 (and 8.0.203.2 if there's another interim workload set, etc.). This is a departure from Semantic Versioning, but appears to be the best way to have an understandable version number for interim workload set releases.

Note that the (possibly 4-part) workload set version will be what is displayed by the .NET CLI and can be specified in places such as the command line and global.json files, but it won't be used as a literal package verison for any NuGet packages. NuGet package versions will remain semantically versions. For the NuGet packages that represent the workload set, there will be a mapping from the workload set version to both the package ID and version, where the feature band is part of the package ID, freeing up space in the version for the additional interim release number.

Some examples of possible workload set versions:

- `8.0.203` - Regular monthly release
- `8.0.203.1` - Interim workload set release
- `8.0.204-preview.1` - Preview interim release of changes that are expected to be incuded in 8.0.204
- `8.0.203.1-preview.1` - Preview interim release of changes that are expected to be released in a workload set before 8.0.204
- `9.0.100-preview.2` - Workload set for .NET SDK preview release
- `8.0.201-servicing.23015` - Daily build of dotnet/workload-versions repo
- `8.0.201-ci.maui.23015` - Workload set corresponding to daily build of maui repo

## Baseline workload versions

.NET SDK workloads have similar shipping deadlines as the .NET SDK. That means that the .NET SDK itself can't include final versions of workloads which are built outside of the .NET build, as building and signing off on those workloads happens in parallel with .NET build and signoff. So the .NET SDK ships with *baseline* workload manifests, which are mainly used to enable the .NET SDK to list which workloads are available, and to know if a project requires a workload which isn't installed. By default, when a workload is installed via the .NET CLI, the .NET SDK will first look for and update to the latest workload manifests for the current feature band before installing workloads.
Expand Down

0 comments on commit e3dd128

Please sign in to comment.