内容主要来源 https://docs.asp.net/en/latest/conceptual-overview/dotnetcore.html
什么是.NET Core
.NET Core 5 包括模块化的运行时和库实现,是.NET Framework的子集。
他包括一系列的库,称之为“CoreFX”,一个精简、优化的运行时,叫做“CoreCLR”。他们两者都是通过NuGet发布的。根据功能不同CoreFX是分解为不同的包的,一般名称是System.[module].因此带来了.NET Core的 portability,所以可以将应用和CoreCLR一起打包部署,而不依赖与已经安装版本的.NET(也即是windows上的.NET Framework).因为.NET Core是随应用一起打包发布的,所以不同应用可以打包不同版本的.NET Core,也可以单独升级其版本。
CoreFX是组件化的一系列库,每一个组件只有最小依赖(e.g. System.Collections仅仅依赖System.Runtime,而不是System.Xml).这就使得能够在应用发布时实现CoreFX库的最小发布(随CoreCLR一起)。CoreFX includes collections, console access, diagnostics, IO, LINQ, JSON, XML, and regular expression support, just to name a few libraries. 另一个好处就是CoreFX使开发者可以使用一个跨平台的公共库。
.NET Core背后的动机
最早2002年.NET 作为一个单独的Framework发布,后来逐渐针对不同平台发布了不同的版本,如the .NET Compact Framework for mobile devices等。除此之外还有针对Linux、Mac和Native ios 和安卓系统的Mono and Xamarin。对于每一个平台,都有一个单独的.NET栈(包括运行是,framework,app model)。.NET Core的主要目的就是提供一个单一的、模块化的、跨平台的.NET ,使得能够运行在所有平台上。.NET Core是开源项目,Mono社区可以从CoreFX中受益,.NET Core不会取代Mono,但是他允许Mono社区参考和共享某些公共库,而不是复制。
另一个压力是来自服务器端,通过构建CoreFX,允许应用只包含他们所需要的那一部分的CoreFX(也即是pay for play model),因此可以最小化依赖。带来的好处就是,减少补丁和升级数量,以及其带来的影响,也减少了应用大小。
使用.NET Core构建应用
.NET Core可以构建Web app,console app和native mobile app. .NET Execution Environment(DNX)提供了一个块平台的runtime host,能够用其构建基于.NET Core的跨平台应用,运行与Windows,Linux,Mac。DNX是在.NET Core上运行ASP.NET 应用的基础。 事实上DNX是支持交叉编译的,targeting both of these frameworks in a single project。在vs2015中的项目模板就是如此的,在ASP.NET 5的project.json中,frameworks部分,就是包括dnx451和dnxcore50。
"frameworks": {
"dnx451": { }, 这是代表.NET
Framework
"dnxcore50": { } 这是代表.NET
Core 5(5.0)
},
在项目中,你可以用编译指令#if来判断版本,如下
#if DNX451
//
utilize resource only available with .NET Framework
#endif
可以根据项目需求,可以只使用dnx51或者dnxcore50,但是在ASP.NET 4.6(含)之前的版本都需要使用.NET
Framework.
.NET Core和NuGet
使用NuGet可以更加便捷的使用.NET Core的各个库,这意味着应用可以列出一个只包含自己所需的一个NuGet包列表(以及对应的版本信息)。这个列表可以包含system/framework也可以包含第三方依赖。而且第三方依赖可以express他们对Framework特性的依赖,使得能够在开发和编译过程中获取合适版本的包。举个例子,如果你需要不可变集合,你可以通过NuGet安装System.Collections.Immutable包。NuGet版本也会和程序集版本匹配,会使用semantic versioning 。
Note:尽管CoreFX可以通过NuGet来获取很多的单独的包,但是他还是或作为一个整体来进行周期性的发布和测试。这种发布相对单独包的发布,很大可能上是频率比较低的,使得有时间可以进行必要的test,fix和distribution process。
总结
.NET Core is a
modular, streamlined subset of the .NET Framework and CLR. It is fully
open-source and provides a common set of libraries that can be targeted across
numerous platforms. Its factored approach allows applications to take
dependencies only on those portions of the CoreFX that they use, and the
smaller runtime is ideal for deployment to both small devices (though it
doesn’t yet support any) as well as cloud-optimized environments that need to
be able to run many small applications side-by-side. Support for targeting .NET
Core is built into the ASP.NET 5 project templates that ship with Visual Studio
2015.