.NET 程序是基于. NET framework,.NET Core,Mono,UWP[.NET 实现] 开发和运行的 , 定义以上[.NET 实现] 的标准规范称为. NET Standard
L1:.NET Standard
.NET 标准是一组 API 集合, 由上层三种[.NET 实现] 的 Basic Class Library 实现, 更正式的说法, 由统一契约集合构成的规范, 这个集合确保了在不同[.NET 实现] 之间的可移植性, 能让你的代码 run everywhere.
.NET Standard 也是一个 target framework. 如果您的代码针对的是. NET Standard 的一个版本, 那它可以在任意一个 支持该. NET Standard 版本的. NET 实现上运行.
L2: [.NET 实现]
上图给出的是微软积极支持和维护的有三个主要的[.NET 实现] :.NET Framework,.NET Core,Mono
1.NET Framework
最早期的. NET 实现, 4.5 + 版本开始实现. NET Standard, 面向特定. NET Standard 版本的代码可以在 4.5 + 特定版本的. NET Framework 平台上编译和运行.
早期的微软比较闭源,.NET Framework 是为构建面向 Windows 桌面环境而设计的, 针对不同的应用程序形态设计了 WINFORM, ASP.NET,WPF
2.NET Core
是近几年微软拥抱开源的结晶,.NetCore 是一个跨平台的[.NET 实现] , 因为原生实现了. NET Standard(完全没有版本包袱), 面向. NETStandard 的代码可以在. NET Core 平台上编译和运行.
针对 web 程序. NetCore 准备了 ASP.NECore 框架, 定位是微软新一代高性能, 开源, 跨平台 Web 开发框架, 目前最新稳定版本为 2.2
另外. NetCore 3.0 即将支持 WINFORM,WPF, 这样将全面覆盖. Net Framework 支持的应用程序形态.
3 Mono 是一个微小运行时的 [.NET 实现] , 驱动 Xamarin, 用于 Android,iOS 等开发, 支持目前所有公开的. NET standard 版本.
本人近些年工作在. NetCore 平台, 有一些宏观上的经验之谈, 可供参考.
一:.NetCore 有两种主要的 primary-based 的部署目标:
- netstandard
- netcoreapp
部署目标是在 Target Framework Moniker 中定义, 决定了程序的部署定位.
在实践中: 项目早期可能是定位是 netstandard, 后面随着项目演进, 依赖的库越来越多, 大部分都会变成 netcoreapp.
如 L1 所述 .NetStandard 也是一个 target framework, 旨在在多个运行时 (跨越. Net Framework,.NET Core, XAMARIN) 上运行的程序应该以此框架为目标.
- <Project Sdk="Microsoft.NET.Sdk">
- <PropertyGroup>
- <TargetFramework>netstandard1.6</TargetFramework>
- </PropertyGroup>
- </Project>
伴随项目演进, 程序依赖的某些库可能只有针对 .NetCore 的版本; 从生产实际看, 部署环境只会部署一套. Net Core 运行时, 所以后期项目很大可能性会演进成 针对 .Net Core 运行时部署.
<TargetFramework>netcoreapp2.2</TargetFramework>
二: 开发环境存在多 SDK, 多 Runtime 版本时, 应当知晓 .NET Core 工具, SDK 和运行时版本选择的策略.
1 当运行 SDK 命令, 会使用安装的最新版本命令
SDK 命令包括 dotnet new/ dotnet run, 即使项目生成文件被指定为早期版本的运行时 或 安装的最新版本 SDK 是预览版, SDK 依旧使用安装的最新 SDK 版本
2 目标框架标记 target framework monikers 定义编译时刻的 API
编译. NetCore 程序的 API 是在项目文件的 Target framework Moniker 中定义的,
- <TargetFramework>
- netcoreapp2.0
- </TargetFramework>
- <TargetFrameworks>
- netcoreapp2.0;net47
- </TargetFrameworks>
3 运行. NetCore 程序( 框架独立的. NetCore 程序 ), 在部署服务器上会适用版本前滚的策略
在项目文件中指定了 netcoreapp2.0, 在部署环境中 2.0.4 是安装的最新运行时版本, 那么就会使用 2.0.4 运行时版本
4 发布自包含的程序, 自包含的部署程序会包含指定的运行时
部署自包含. NetCore 程序时, 部署文件包含了. NetCore 运行时和程序依赖的库文件, 自包含项目并不依赖 部署服务器上运行时环境, 运行时版本选择发生在发布阶段, 而不是在运行阶段.
目前 自包含. NetCore 程序使用场景不多, 一般用于需要将程序应用到复杂的多种客户环境中, 这种部署方式可将运行时和依赖环境打包, 不用去提前知晓客户服务器运行时.
Tip: 针对策略1 有些特殊情况, 你需要使用早期的 SDK 版本, 可在 global.JSON 文件中指定该早期版本:
- {
- "sdk": {
- "version": "2.2.3"
- }
- }
本文没有大篇幅讲解 .NETCore SDK 和 CommandLine 的用法, 照葫芦画瓢即可, 特意指出 选择部署目标, 多 SDK 选择策略上的经验, 读者可参照应用.
作者: JulianHuang
感谢您的认真阅读, 如有问题请大胆斧正; 觉得有用, 请下方 或加关注.
来源: https://www.cnblogs.com/JulianHuang/p/11126915.html