ASP.NET Core 2.2 基础知识(十八) 托管和部署 概述

 为了方便演示,以 .NET Core 控制台应用程序讲解.

我们新建一个控制台应用程序,安装 "Newtonsoft.Json" Nuget 包,然后右键点击该项目,选择"发布":

 

我们依次选择"文件",设置好路径,最后点击创建配置文件,界面变成了下面这样:

 

然后我们点击"配置"

 

那么,问题来了."部署模式" 里面有两个选项:

1.当选择框架依赖时,"目标运行时"有:"可移植","win-x86","win-x64","osx-64","linux-x64" 5个选项.

2.当选择"独立"时,"目标运行时"没有"可移植"这个选项.

我们到底应该怎么选择?

不要做思想的巨人,行动的矮子!

没事儿走两步!

依赖框架的部署 (FDD) : 框架依赖 + 可移植

 

以这种方法发布后,进入发布的文件夹发现,居然只有5个文件 !

 

1个应用程序的程序集,1个pdb,2个json,1个第三方依赖项.

咦?怎么没有.EXE 文件?没有 .exe 文件,我怎么运行该项目?(其实,进入到该项目的debug文件夹,你会发现也没有.exe文件)

这样运行:(为了方便,我通过 VS Code 进入该文件夹)

现在,我们回过头来看官方对这种方式的解释:

依赖框架的部署 (FDD) : 顾名思义,依赖目标系统上存在的共享系统级版本的 .NET Core.由于已存在 .NET Core,因此应用在 .NET Core 安装程序间也是可移植的.应用仅包含其自己的代码和任何位于 .NET Core 库外的第三方依赖项.FDD 包含可通过在命令行中使用 dotnet 实用程序启动的 .dll 文件。 例如,dotnet app.dll 就可以运行一个名为 app 的应用程序.

结合我们的实际操作,大概就是这几个意思:

1.FDD 只会部署应用程序和第三方依赖项,也就是发布生成的这4个文件: MyConsole.dll ,MyConsole.pdb , 应用程序配置文件 MyConsole.deps.json,以及第三方依赖项 Newtonsoft.json.dll .

2.名字既然叫"依赖框架",那依赖的系统肯定必须要有框架才行!也就是说,应用程序将要部署到的目标系统上,必须要有 .NET Core ;

3.应用程序将使用目标系统上存在的 .NET Core 版本.这就是最后一个文件的意义.我们用记事本打开 MyConsole.runtimeconfig.json ,可以看出,该文件指明了我们需要依赖的.Net Core 的版本: "2.2.0"

复制代码
{   "runtimeOptions": {     "tfm": "netcoreapp2.2",     "framework": {       "name": "Microsoft.NETCore.App",       "version": "2.2.0"     }   } }
复制代码

FDD 也是 .NET Core 和 ASP.NET Core 应用程序的默认部署模型.该部署方式的优缺点如下:

优点:

  • 不需要提前定义 .NET Core 应用将在其上运行的目标操作系统。 因为无论什么操作系统,.NET Core 的可执行文件和库都是用通用的 PE 文件格式,因此,无论什么基础操作系统,.NET Core 都可执行应用。 

  • 部署包很小。 只需部署应用及其依赖项,而无需部署 .NET Core 本身。

  • 除非重写,否则 FDD 将使用目标系统上安装的最新服务运行时。 这允许应用程序使用 .NET Core 运行时的最新修补版本。

  • 许多应用都可使用相同的 .NET Core 安装,从而降低了主机系统上磁盘空间和内存使用量。

缺点:

  • 只有目标系统上安装的 .NET Core 版本不低于应用程序要求的版本时,应用才能运行。

  • 如果不了解将来版本,.NET Core 运行时和库可能发生更改。 在极少数情况下,这可能会更改应用的行为。

官方的这个优缺点已经说得很详细了.其中,我对标红的这句缺点实验了一下,结果分享给大家:

首先,我们将 MyConsole.runtimeconfig.json 文件中的版本号修改成 "2.3.0":

复制代码
{   "runtimeOptions": {     "tfm": "netcoreapp2.2",     "framework": {       "name": "Microsoft.NETCore.App",       "version": "2.3.0"      }   } }
复制代码

接着,我们在命令行中输入 dotnet myconsole.dll 运行该项目:

运行失败!

错误信息大概意思如下:

第1句:没有找到任何可以兼容的 framework 版本.

第2句:没有找到指定的 2.3.0 版本的 framework "Microsoft .NETCore.App" .

最后一句:(该系统)只安装了 2.2.0 版本.

现在 ,我们将版本号修改成 2.1.0 试试看:

复制代码
{   "runtimeOptions": {     "tfm": "netcoreapp2.2",     "framework": {       "name": "Microsoft.NETCore.App",       "version": "2.1.0"     }   } }
复制代码

正常运行了:

 

又 12点 了.睡了.明天继续

---------------------------------------------------------------------------

2019.1.10

依赖框架的可执行文件 (FDE) : 框架依赖+win-x86/win-x64/osx-64/linux-x64

这是.Net Core 2.2 才开始有的方式.我们将"目标运行时" 设为 win-x64 ,演示效果,左边是 该方式发布后的文件,右边是用 上述 FDD 方式发布的文件:

 

 

可以看出来,FDE 只比 FDD 多了一个 .exe 文件而已,意义也很明显了.

 

独立部署 (SCD) : 独立+win-x86/win-x64/osx-64/linux-x64

同样,我们将"目标运行时"设为 win-x64 演示效果:

 

 

只截取了一小部分,实际一共有218个文件.共 66.7MB , 而上面的 FDD,FDE 只有 700KB 左右.

看了实际效果后,我们回头看看官方对于 SCD 的解释:

对于独立部署,可以部署应用和所需的第三方依赖项以及生成应用所使用的 .NET Core 版本。 创建 SCD 不包括各种平台上的 .N

50000+
5万行代码练就真实本领
17年
创办于2008年老牌培训机构
1000+
合作企业
98%
就业率

联系我们

电话咨询

0532-85025005

扫码添加微信