同一台服务器上的多个 .NET 版本
Multiple versions of .NET on the same server
所以我一直都知道 运行 可以在一台计算机(客户端或服务器等)上安装多个版本的 .NET 框架。 This question,虽然有点老了,说到这里。
然而,前阵子,我的任务是创建一个新的 ASP.NET 应用程序,我试图决定是使用完整的 .NET 框架还是 .NET Core,我遇到了 this article 来自微软。文章指出,如果我需要并行安装框架,我应该使用 .NET Core。这是完整的引述:
To install applications with dependencies on different versions of
.NET, we recommend .NET Core. .NET Core offers side-by-side
installation of different versions of the .NET Core runtime on the
same machine. This side-by-side installation allows multiple services
on the same server, each of them on its own version of .NET Core.
但我认为没有 .NET Core 就可以并行安装框架?我错过了什么?
我问的原因是我目前有一个使用 .NET Framework 2.0 的旧 ASP.NET 应用程序,而我现在正在开发一个使用 .NET Core 的应用程序。我 运行 遇到了一些问题,这些问题让我考虑将 .NET Core 应用程序切换到完整的 .NET Framework 4.6,但微软的那篇文章让我有点困惑。
问题是:我能否在同一个 Windows 2008 R2 服务器上 运行 两个应用程序(.NET Framework 2.0 和 4.6)都没有问题?如果是,那这篇文章指的是什么?
最后一件事:我的两个应用程序(旧的和新的)都使用 Crystal 报告。新应用程序可能需要比旧应用程序更新版本的 Crystal 报告。我可以在同一台服务器上 运行 不同版本的 Crystal 报告吗?在这种情况下,我会像 Microsoft 文章中所说的那样需要 .NET Core 吗?
谢谢
Side-by-side 框架的安装不仅是可能的,而且是事实。 NET 1.0、2.0 和 4.0 之后的所有版本都有单独的安装。然而:
- .NET 3.0 和 3.5 都使用 2.0 运行时间,因此并不是真正独立的。
- 同样,.NET 4.5 和以上所有版本都使用 4.0 运行 时间,因此彼此不分离。更复杂的是,当您安装更高版本时,基础 4.0 运行时间实际上已升级。
- 最后但同样重要的是,选择哪个框架版本 运行 您的应用程序已随 .NET 4.0 发生变化。这个规则相当复杂,取决于安装的版本和应用程序配置;有关完整讨论,请参阅 this article。
对于你的问题,那么:
Will I be able to run both apps (.NET framework 2.0 and 4.6) on the
same Windows 2008 R2 server without issues?
如果同时安装了 .NET Framework 2.0 和 4.6,则可以。假设没有特殊的配置设置,2.0 应用程序将 运行 在 2.0 框架上,但它也可以配置为使用 4.6 框架(它将自身显示为 4.0 运行 时)。
If so, then what is that article referring to?
这篇文章指的是完整的 .NET Framework 逐渐放弃了完全独立 side-by-side 安装的想法,因为在次要版本(有时甚至是主要版本)之间没有分隔,而 .NET Core 通过允许 self-contained 部署来加倍考虑这个想法。也就是说,不仅 .NET Core 1.0 和 .NET Core 2.0 应用程序可以共存,而不会像 .NET Framework 2.0 和 3.5 应用程序那样存在共享依赖项的风险,甚至两个 .NET Core 1.0 应用程序也可以共存,而无需共享依赖项,这对于完整的 .NET Framework 应用程序是不可能的。如果(比方说)为 .NET 2.0 安装补丁,它将影响所有 .NET 2.0、3.0 和 3.5 应用程序,至少在二进制级别上是这样。您不能选择让某些应用程序受补丁影响而不影响其他应用程序(尽管通常会为破坏兼容性的行为添加配置开关)。
One last thing: both my apps (old and new) use Crystal Reports.
There's a possibility that the new app might need a newer version of
Crystal Reports than the old app. Will I be able to run different
versions of Crystal Reports like this on the same server? Is this the
situation in which I would require .NET Core like the Microsoft
article says?
这与框架无关,取决于 Crystal Reports 本身如何处理版本控制。 According to the manufacturer,答案是肯定的,对于主要版本但不是次要更新:
Side-by-side installation of different major release version of
Crystal Reports designer is supported since Crystal Reports 9,
because each major release version installs the software in different
directory.
您不需要 .NET Core 即可 side-by-side 安装不同的程序集版本。更重要的是,即使您使用了 .NET Core 应用程序的 self-contained 部署,它可能仍然指的是机器上 Crystal Reports 的共享安装,而不是 self-contained 部署Crystal 报告(我认为不存在这样的事情;我什至不确定 Crystal 报告目前在 .NET Core 上是否受支持)。
最后但同样重要的是:请注意,某些版本的 .NET 不再受到官方支持。关于支持哪些版本(以及在何处支持)的政策非常复杂,具体取决于框架是否属于 OS,但 detailed here。 .NET 4.6 有一些非常讨厌的 JIT 编译器错误(已在 4.6.1 中修复),因此您真的不想无论如何都使用它,无论官方支持与否。如果您的服务器尚未安装 .NET 2.0 以上的任何版本,您也可以直接跳转到支持的最新版本 OS(截至撰写本文时为 4.8)。
所以我一直都知道 运行 可以在一台计算机(客户端或服务器等)上安装多个版本的 .NET 框架。 This question,虽然有点老了,说到这里。
然而,前阵子,我的任务是创建一个新的 ASP.NET 应用程序,我试图决定是使用完整的 .NET 框架还是 .NET Core,我遇到了 this article 来自微软。文章指出,如果我需要并行安装框架,我应该使用 .NET Core。这是完整的引述:
To install applications with dependencies on different versions of .NET, we recommend .NET Core. .NET Core offers side-by-side installation of different versions of the .NET Core runtime on the same machine. This side-by-side installation allows multiple services on the same server, each of them on its own version of .NET Core.
但我认为没有 .NET Core 就可以并行安装框架?我错过了什么?
我问的原因是我目前有一个使用 .NET Framework 2.0 的旧 ASP.NET 应用程序,而我现在正在开发一个使用 .NET Core 的应用程序。我 运行 遇到了一些问题,这些问题让我考虑将 .NET Core 应用程序切换到完整的 .NET Framework 4.6,但微软的那篇文章让我有点困惑。
问题是:我能否在同一个 Windows 2008 R2 服务器上 运行 两个应用程序(.NET Framework 2.0 和 4.6)都没有问题?如果是,那这篇文章指的是什么?
最后一件事:我的两个应用程序(旧的和新的)都使用 Crystal 报告。新应用程序可能需要比旧应用程序更新版本的 Crystal 报告。我可以在同一台服务器上 运行 不同版本的 Crystal 报告吗?在这种情况下,我会像 Microsoft 文章中所说的那样需要 .NET Core 吗?
谢谢
Side-by-side 框架的安装不仅是可能的,而且是事实。 NET 1.0、2.0 和 4.0 之后的所有版本都有单独的安装。然而:
- .NET 3.0 和 3.5 都使用 2.0 运行时间,因此并不是真正独立的。
- 同样,.NET 4.5 和以上所有版本都使用 4.0 运行 时间,因此彼此不分离。更复杂的是,当您安装更高版本时,基础 4.0 运行时间实际上已升级。
- 最后但同样重要的是,选择哪个框架版本 运行 您的应用程序已随 .NET 4.0 发生变化。这个规则相当复杂,取决于安装的版本和应用程序配置;有关完整讨论,请参阅 this article。
对于你的问题,那么:
Will I be able to run both apps (.NET framework 2.0 and 4.6) on the same Windows 2008 R2 server without issues?
如果同时安装了 .NET Framework 2.0 和 4.6,则可以。假设没有特殊的配置设置,2.0 应用程序将 运行 在 2.0 框架上,但它也可以配置为使用 4.6 框架(它将自身显示为 4.0 运行 时)。
If so, then what is that article referring to?
这篇文章指的是完整的 .NET Framework 逐渐放弃了完全独立 side-by-side 安装的想法,因为在次要版本(有时甚至是主要版本)之间没有分隔,而 .NET Core 通过允许 self-contained 部署来加倍考虑这个想法。也就是说,不仅 .NET Core 1.0 和 .NET Core 2.0 应用程序可以共存,而不会像 .NET Framework 2.0 和 3.5 应用程序那样存在共享依赖项的风险,甚至两个 .NET Core 1.0 应用程序也可以共存,而无需共享依赖项,这对于完整的 .NET Framework 应用程序是不可能的。如果(比方说)为 .NET 2.0 安装补丁,它将影响所有 .NET 2.0、3.0 和 3.5 应用程序,至少在二进制级别上是这样。您不能选择让某些应用程序受补丁影响而不影响其他应用程序(尽管通常会为破坏兼容性的行为添加配置开关)。
One last thing: both my apps (old and new) use Crystal Reports. There's a possibility that the new app might need a newer version of Crystal Reports than the old app. Will I be able to run different versions of Crystal Reports like this on the same server? Is this the situation in which I would require .NET Core like the Microsoft article says?
这与框架无关,取决于 Crystal Reports 本身如何处理版本控制。 According to the manufacturer,答案是肯定的,对于主要版本但不是次要更新:
Side-by-side installation of different major release version of Crystal Reports designer is supported since Crystal Reports 9, because each major release version installs the software in different directory.
您不需要 .NET Core 即可 side-by-side 安装不同的程序集版本。更重要的是,即使您使用了 .NET Core 应用程序的 self-contained 部署,它可能仍然指的是机器上 Crystal Reports 的共享安装,而不是 self-contained 部署Crystal 报告(我认为不存在这样的事情;我什至不确定 Crystal 报告目前在 .NET Core 上是否受支持)。
最后但同样重要的是:请注意,某些版本的 .NET 不再受到官方支持。关于支持哪些版本(以及在何处支持)的政策非常复杂,具体取决于框架是否属于 OS,但 detailed here。 .NET 4.6 有一些非常讨厌的 JIT 编译器错误(已在 4.6.1 中修复),因此您真的不想无论如何都使用它,无论官方支持与否。如果您的服务器尚未安装 .NET 2.0 以上的任何版本,您也可以直接跳转到支持的最新版本 OS(截至撰写本文时为 4.8)。