If I've installed the latest version of the .NET Core Runtime (as of now, that's version 2.2.3):
https://dotnet.microsoft.com/download/dotnet-core/2.2
Is that one installation backwards-compatible with previous releases of .NET Core?
For example, will the above installation be compatible with an app which targets:
- netcoreapp1.0
- netcoreapp2.0
- netcoreapp2.1
- netcoreapp2.2
I realize that the .NET runtimes can be installed side-by-side. However, that does not answer my question. Is the one 2.2 installation backwards compatible with previous releases, such that additional runtimes are not necessary?
tldr;
Yes. By installing .NET Core Runtime 2.2.3, you can run apps which target netcoreapp2.0, netcoreapp2.1, and netcoreapp2.2, without requiring additional runtimes to be installed.
Explanation
Microsoft:
In other words: (Minor updates within the same major release are backwards compatible)
Microsoft:
In other words: (The latest SDK can target previous runtimes)
Microsoft:
In other words: (Generally speaking, you should only need to install the latest SDK/runtime)
Microsoft:
In other words: (As you install additional SDKs/runtimes side-by-side over time, you should occasionally remove older versions, in favor of the latest)
Source: https://docs.microsoft.com/en-us/dotnet/core/versions/remove-runtime-sdk-versions?tabs=windows
.NET Core Versioning
According to documentation:
In other words, .NET Core runtime releases follow the Semantic Versioning scheme:
[Major].[Minor].[Patch]
Where:
So, the answer to the above question is based on Semantic Versioning:
With this understanding, when .NET Core apps are built/published/restored, they target a major release and feature set as indicated by the major/minor version numbers found in the runtime name. So, netcoreapp2.2 is backwards compatible with netcoreapp2.1, which, in turn, is backwards-compatible with netcoreapp2.0. But all are incompatible with netcoreapp1.x or netcoreapp3.x.
With one installation of .NET Core 2.1.5 runtime, and assuming a framework-dependent publish deployment, you would be able to run apps targeting:
But not:
If there are multiple runtimes installed, then the exact runtime is chosen based on the latest runtime installed with the highest patch.
About the SDK
The SDK is not based on Semantic Versioning. However, each SDK targets a maximum .NET Core Runtime, and supports every version prior to it.
That means, you don't need to install more than one SDK on your build server if you want to build against multiple runtimes (even though you could). The SDK already includes all the necessary runtimes to build applications on the current version (or any prior version) out-of-the-box. For example, if you install .NET Core 2.2.105 SDK, you can build for netcoreapp1.0, netcoreapp2.0, netcoreapp2.1, or netcoreapp2.2. But you can't build for .NET Core 2.3, or 3.0.
An Example
Suppose I have a build server, which has the latest .NET Core SDK installed (SDK 2.2.105 - 2.2.3 Runtime).
Although, SDK 2.2.105 is installed, I might want to build and publish a .NET Core 2.1 app:
/p:Configuration=Release
- configure for Release-r win-x64
- target Windows deployment (rather than portable)--self-contained false
- Framework dependent deployment (requires runtime to be installed on host)/p:IsWebConfigTransformDisabled=true
- do not transform web.config to avoid errors with the default web.config generated by Visual Studio (may be needed when migrating from 2.1 to 2.2)--framework netcoreapp2.1
- explicitly target a runtime framework/p:DebugSymbols=false /p:DebugType=None
- disable .PDB filesThis build could be installed on a Production server with the latest runtime .NET Core Runtime + Hosting Bundle 2.2.3 - no other runtimes (or SDK) are necessary
Hope this helps someone else
A few usage examples demonstrate the behavior, if you target 2.0:
Please refer following link in Microsoft Docs Microsoft Link