ASP.NET vNext or .NET vNext?

从概念和基础开始

vNext在曝光以来绝大多数以ASP.NET vNext这样的的字眼出现,为什么这边会提及.NET vNext?原因是我认为ASP.NET只是其中的一种开发框架而已,其中真正核心重要的乃是底层的支撑层,至于底层还有些什么内容,下面会进行一次分析。

.NET Framework、Mono、.NET Core都是什么鬼?

相信有不少人对这一次vNext新诞生的名词抱有许多疑惑,它们到底是做什么的?负责什么内容?扮演者什么样的角色。

.NET Framework

这个我相信大家都不会感到陌生,做.NET平台相关的开发者都应该熟悉至少是了解其中的大概(虽然现在这样的人还是占少数),.NET Framework整个架构图非常大,但针对今天的主题细分为两大块:CLR(公共语言运行时)、FCL(框架类库)。

CLR是负责执行IL(中间语言)而FCL则是微软提供给开发者的快速开发类库,这些代码完全可以由开发者自己编写与我们平常写的代码本质上并没有多大的差异。

Mono

Mono与.NET Framework类似,是对于.NET Framework跨平台的移植,xamarin就是基于它的,也是风风火火。

.NET Core

今天的主角之一,.NET Fremework中的两大块CLR、FCL它也有,不过进行了更名与重构。

CLR被命名为:CoreCLR(.NET核心公共语言运行库)

FCL被命名为:CoreFX(.NET核心库)

在两大块面前大家先对号入座就好了。

CoreCLR

CoreCLR向外暴露了:Roslyn、LLILC(lilac)。

Roslyn

这个大家比较熟悉,它向C#、Visual Basic提供了丰富的代码分析API和编译器。一开始我以为C#、VB代码到二进制代码的编译完全由它来完成,后面才发现它的背后有一个默默付出的功臣:LLILC,而它最主要的作用则是代码分析编译的动作是转交给LLILC的。

LLILC

真正的编译工作者。官方以后将提供:JIT(Just in time运行时编译)、AOT(Ahead of time运行前编译)两种编译方式。不过目前只有JIT,而AOT目前是Universal Windows Platform(UWP)的特权,相信不久的将来我们会迎来全平台的AOT。

JIT方式的编译实现现在叫做:RyuJIT。

JIT编译架构

AOT编译架构

相比之前的特色

模块化

在此之前大伙能想象CLR、FCL可以根据设定的版本号自动进行获取吗?而.NET Core基于模块化这一特性实现了这一点,以后大伙不需要再提前安装.NET Framework对应的版本而可以直接使用到不同版本的特性。这对于正在运行的服务器安装新的.NET Framework或更新.NET Framework带来了一次完美的解决,以后在使用.NET平台下新特性时不需要再担心更新完成之后服务器是否需要重启,因为这一切都是模块化的可选择性加载的。

跨平台

vNext发布之初最大的特性就是可以在Linux、OSX等操作系统上运行了,这也是大家觉得最需要醉激动的。但个人只是觉得跨平台是.NET这次革命以来带来的一个成果、结果而已,并不让我觉得很不可思议。

当然发展了许多年的.NET如今跨平台并不是毫无成本的,如果想要跨平台就意味着现在存在的小、中大型项目几乎不可移植,具体的我们后面再看。

开放

这是特性是离我们最远却最有意义的一点(本质上说这不关平台的事,而是关乎于微软)。这意味着我们可以为 CoreCLR(CLR)、CoreFX(FCL)进行贡献以帮助.NET更加完善。

为什么说离我们最远?作者也有开源一些项目深知想要为某个开源项目贡献是一件多么不易的事情,而得到它人的贡献更是一件特别特别难的事情。所以大多数开发者都不会用到此特性。

为什么最有意义?这一点很难说清,需要时间去证明,如果微软能够营造一个不错的社区环境那么这一点以后一定会体现出来。

DNVM、DNX、DNU、KVM、KPM、KRE是些什么鬼?

我们先来看看每个缩写的全称和中文名称。

DNVM:.NET Version Manager(.NET版本管理)

由于要实现跨平台的目录,微软提供了DNVM功能,DNVM是ASP.NET最底层的内容,它是一组Powershell脚本,用于启动指定版本的ASP.NET运行环境,并且可以在同一台机器的同一时间点上通过使用Nuget工具来管理各种版本的ASP.NET运行环境(DNX),以及进行相应的升级操作。

之前我们提到模块化的特性时有说过现在我们不需要到处去找.NET Framework安装包去单独安装不同版本的.NET Framework了,而是由一个工具进行统一的管理(安装、卸载、升级等),可以把它理解成一个“软件管家”不过它目前只有一个软件:.NET Core(不同的版本、CPU架构)。以后在开放项目时如果用了.NET Core v2版本,那么我们需要在服务器上使用该工具安装.NET Core v2。(安装过程非常的快,每个不同的版本包含了完整的.NET Core中提及的内容)

DNX:.NET Execution Environment(.NET执行环境)

DNX是ASP.NET程序的运行环境,用于启动并运行ASP.NET程序。该运行环境包括了编译系统、SDK工具集、Native CLR宿主环境。可以使用DNVM管理各种版本的DNX,如dnvm list命令可以列出所有可用的DNX环境,而dnvm install 1.0.0-beta4则可以将指定版本的DNX安装到.dnx文件夹,你可以在%USERPROFILE%\.dnx\runtimes目录下找到已安装所有版本的DNX。不同的操作系统有不同的DNX版本。

dnx.exe:dnx.exe是用于启动自宿主环境(Self-Hosting)的命令行工具,在使用命令行代码进行自宿主环境启动程序时,dnx负责查找并调用CLR Native Host,dnx命令是整个运行环境的入口点,你可以使用dnx run来启动程序。

我们的代码(C#、VB)是由.NET Core来执行的而.NET Core是由DNX来执行的。

DNU:DNX Utility(.NET执行环境实用工具)

是一个命令行的包管理器,包含在DNX内,所以只要安装了DNX,就可以使用dnu命令,其可以用于恢复程序包、安装程序包、部署程序包等等,比如把project.json里自定义的程序集自动下载下来进行使用。

用过NuGet的应该都清楚我们一般在VisualStudio中进行package的还原,其实NuGet提供了NuGet.exe,微软应该考虑到了集成度才将NuGet.exe包含在了DNX当中,他的作用很简单,为项目进行package的还原。

开发环境还原好了再发布就可以为什么正式环境还需要它?

    vNext一直强调的是云,我们一般在Windows下进行开发(拥有宇宙最强IDE),但线上环境其实是Linux这时候就需要根据不同的运行环境还原不同的package以便能正常运行。

KVM:K Version Manager(K版本管理)

KRE:K Runtime Enviroment(K运行环境)

KPM:K Package Manager(K包管理)

可以发现以D开头的3个东西跟K开头的三个东西名称上非常的类似,到这里你想的没错,微软的改名大队又出动了,在此之前微软将此项目命名为K项目,在此之后肯定要有个专业的名称,微软开发团队对一些内容进行了职责和名称划分。

架构图

这一节的内容部分引用自:理解ASP.NET 5运行时命令:DNVM, DNX, 和DNU,在此感谢张善友前辈为我们提前探好了路。

.NET Framework 4.6和.NET Core 5

上面描述过.NET Framework是我们现在用的.NET框架,.NET Core是新一代的.NET框架,那么他们两个的关系是什么?我们来看一张图。

可以发现

.NET Framework 4.6

支持WPF、Windows Forms、ASP.NET(4&5)

.NET Core 5

只支持ASP.NET 5、Universal Windows Apps(UWP)

这边有一个很有意思的事,Universal Windows Apps(UWP)微软平台(PC、平板、手机)大统一战略中最重要的一环使用的是.NET Core,不难发现.NET Core对于微软来说的重要性。也是微软了筹备了数年的成果。

写在最后

参考资料

http://www.cnblogs.com/shanyou/p/4589930.html
http://www.cnblogs.com/shanyou/p/3764070.html
http://www.cnblogs.com/dudu/p/4257106.html
http://www.cnblogs.com/dudu/p/aspnet5-xre-cross-platform-secret.html
http://www.cnblogs.com/dudu/p/4245809.html
http://www.cnblogs.com/dudu/p/dotnet-core-framework-mono.html
http://www.cnblogs.com/dudu/p/what-is-dotnet-core.html
http://www.cnblogs.com/shanyou/p/4295163.html
http://www.cnblogs.com/dudu/p/what-is-dotnet-core.html

http://dotnet.github.io/core/
https://docs.asp.net/en/latest/conceptual-overview/aspnet.html
https://docs.asp.net/en/latest/conceptual-overview/dotnetcore.html
https://docs.asp.net/en/latest/dnx/overview.html

https://github.com/dotnet/coreclr
https://github.com/dotnet/corefx
https://github.com/dotnet/core

http://dotnet.github.io/core/about/overview.html
http://www.dotnetfoundation.org/netcore

这里感谢:张善友和dudu,感谢他们之前为我们探好了路。

交流方式

QQ群:384413261(RabbitHub)

Email:majian159@live.com

ASP.NET vNext or .NET vNext?的更多相关文章

  1. Visual Studio 2015 开发 ASP.NET 5 有何变化?

    本篇博文目录: ASP.NET 5 模版 ASP.NET 5 目录结构 前端管理工具 无编译开发 Microsoft Git Provider 智能感知和错误信息 Smart Unit Testing ...

  2. Visual Studio 2015 开发 ASP.NET 5 有何变化?(转)

    出处:http://www.cnblogs.com/xishuai/p/visual-studio-2015-preview-asp-net-5-change.html 本篇博文目录: ASP.NET ...

  3. 这个算asp.net的一个bug吗?

    asp.net设置按钮Enabled="false"后OnClientClick中添加的验证脚本消失了 下面的确可以 <asp:Button ID="btnRegi ...

  4. 【翻译】ASP.NET Web API是什么?

    原文 [翻译]ASP.NET Web API是什么? 说明:随微软ASP.NET MVC 4一起发布的还有一个框架,叫做ASP.NET Web API.目前国内关注这项技术的人似乎还很少,这方面的文章 ...

  5. 用例子看ASP.NET Core Identity是什么?

    原文:用例子看ASP.NET Core Identity是什么? 目录 前言 基于声明的认证(Claims-based Authentication) Claim 在ASP.NET Core Iden ...

  6. 网站迁移纪实:从Web Form 到 Asp.Net Core (Abp vNext 自定义开发)

    问题和需求 从2004年上线,ZLDNN.COM运行已经超过16年了,一直使用DotNetNuke平台(现在叫DNN Platform),从最初的DotNetNuke 2.1到现在使用的7.4.先是在 ...

  7. IIS托管Asp.net Core及Abp VNext

    默认方式安装IIS后,从官方网站下载IIS模块 https://dotnet.microsoft.com/download/dotnet-core/3.1 2个都需要安装 安装后,新建网站指向发布的磁 ...

  8. web系统开发为什么用asp.net MVC,为什么不用?

     向高手咨询下,现在asp.net MVC很流行,但我好像提不起兴趣.企业级Web应用,使用纯HTML+jquery交互+Http Handler(或WebAPI),不是挺好的吗?有很多优点:1.Ht ...

  9. 看stackoverflow大牛如何回答何时在ASP.NET中使用异步控制器?

    转载自博客园:http://farb.cnblogs.com/ 今天无意中看到stackoverflow上一个很好的问答,个人觉得很有价值,所以翻译过来和大家共享!希望大家能相互交流. 在ASP.NE ...

随机推荐

  1. .Net C# Windows Service于server无法启动,错误 193:0xc1

    1.情况说明:的近期发展windows维修,当地win7系统正常.把server安装会失败. 图中的引导失败的例子.: 解决方法:执行->输入:eventvwr.msc    打开你的事件查看器 ...

  2. ecshop 后台添加 成本价 利润

    ecshop后台admin中的商品操作php文件,goods.php替换为下面的代码, 还要在数据库商品本店售价后门添加  cost  字段 为 商品成本价 ecs_goods表中添加  cost  ...

  3. dede 标签

     ◆织梦内容管理系统模板标签代码参考 [Arclist 标记] 这个标记是DedeCms最常用的一个标记,也叫自由列表标记,其中 hotart.coolart.likeart.artlist.imgl ...

  4. ssh 实体关系分析确立(ER图-实体关系图)

    比較简单的方式就是依据模仿同类产品,依据同类产品的进行模仿,表单就是一个起码要加的字段,然后依据项目须要额外添加字段. 注意:实体类之间的引用关系还须要考虑性能的影响.如:单向或是双向. 表设计: 设 ...

  5. 黄聪:Microsoft Enterprise Library 5.0 系列教程(七) Exception Handling Application Block

    原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(七) Exception Handling Application Block 使用企业库异常处理应用程序模块的 ...

  6. 用户手册User Guide的写法

    下面的内容仅代表个人观点,是在工作中总结出来的,如果有错误之处,还请指教. 转载请注明来自博客园---”邦邦酱好“: http://www.cnblogs.com/bangbangjiang/p/36 ...

  7. TP-LINK telnet远程 重启路由器(转)

    突然断网,以前房东的路由器管理页面可以打开,今天突然间就打不开了.ping了下,可以ping通,于是就想起了房东的路由器是TP-LINK的 可以 telnet登陆的.每次,断网,我都会重启房东的路由器 ...

  8. 轻松管理您的网络password

    在互联网在现在这个时代,,我们注册了很多帐户.支付宝账号password,各种宝账户password.微信,QQ,电话password,购买各种网站,金融password,它是不是让孩子们的鞋子瞬间淡 ...

  9. Mongoose即使是简单的表查询

    从我原来的博客尖,欢迎大家光临 http://www.hacke2.cn 像我这篇文章所说的基于Node.js + jade + Mongoose 模仿gokk.tv.当时停止开发是由于我深深的感觉到 ...

  10. HDU 1051:Wooden Sticks

    Wooden Sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...