英文原文:The Next Generation of .NET – ASP.NET vNext
感谢 中奖啦 和 白文 的激情翻译。
在微软北美技术大会(TechEd North America)上,我们宣布了下一代 .NET 的技术创新点。这其中最重要的就是 ASP.NET vNext。我们一直在对 .NET 的核心技术进行优化,尤其是在上个月举行的 Build 大会上发布的 .NET Native 预编译器和 .NET Next Generation JIT (“RyuJIT”)。
在上个月的 Build 大会上,我们宣布了 .NET 基金会。现在,我们正和超过 25 家基于社区的 .NET 项目和组织沟通,邀请他们加入该基金会。大家对 .NET 基金会的兴趣远超我们的预期,这是一个不错的开始。
同样在 Build 大会上发布的还有 .NET Compiler Platform ("Roslyn") 。它包括一个全新的 C# 和 VB 的编译器以及一些将要添加到C# 6 中的新特性。该项目是一个托管在 codeplex 上的开源项目,并且已经接受了一个来自社区的 pull request。
Visual Studio 2013 Update 2 现在已经提供下载了,这次更新给使用 Visual Studio 的开发者带来了多个意义非凡的新特,包括针对 Window Phone 8.1 和通用的 Window 程序的工具。
在我们向前发展的同时,也要关注一下 .NET 当前的优势。目前,.NET 大约有 18 亿个有效安装。无论从哪方面来说,这都是一个非常大的数字,同时这也为你的程序提供了一个广阔的运行平台。
TechEd 中 .NET 的公告
下面是我们在 TechEd 中分享的一些关于 .NET 的公告。
.NET vNext
.NET vNext 作为 .NET Framework 的下一个重要的发布版本,第一次被我们在 TechEd 上提及。我们在 TechEd 和 Build 大会上分享了下一个发布版本中的多个新特性和组件。 你可以使用 Roslyn compilers 来编译 C#6 和 VB,将 ASP.NET vNext 程序部署在服务器或者云端,使用 .NET Native 预编译器来编译你 Windows Store 上程序,并且可以享受由 Next Generation JIT 带来的更快的服务端或桌面程序。
针对现在比较常见的服务端优先和移动端优先的开发需求,我们对 .NET 做了专门的优化。用户对移动端和云端 APP 有更高的性能需求,并且这些程序都运行在专门的硬件或虚拟环境下。我们为 Windows Store 程序提供了 .NET Native 预编译器,为云端程序开发了一个云端优化模式。
.NET vNext 有一个专门为云端环境优化过的模式,该模式允许你在部署程序的时候连同他们所用到的 .NET Framework 的相关库一同部署(译者注:没有用到的库不会添加到里面)。由于 .NET 的运行时和框架中的库部署在了程序基础(app-basis)上。所以在同一台机器上,每一个程序可以运行不同版本的 .NET vNext,并且可以单独升级,互不影响。这些库已经被显著的优化、精简以便减少框架占用的空间,并且将会使用 NuGet 来发布。在这种模式下,和 WPF 以及 Window Forms 相关的一些库已经被移除了。
我们始终以跨平台的思想来开发这个模式,在开发过程中我们和 Xamarin 积极合作,以确保经过云端优化过的 .NET 程序可以运行在装有 Mono 运行时的 Mac 和 Linux 上。.NET 和 ASP.NET 的巨大生产力可以提供给那些使用混合开发环境的团队。
ASP.NET vNext
ASP.NET vNext 是我们在 TechEd 上的一个重大发布。我们已经更新了 ASP.NET 的诸多方面,使 ASP.NET 的程序更容易构建并且在性能方面表现的更好。对于这些网站和服务,我们分别考虑了访问量少的情况和访问量超多的情况。我们开辟了新的场景,这些场景之前是不会在 ASP.NET 中发生的。
我们设计 ASP.NET 的时候考虑了一些关键性的设计原则,如下所示:
ASP.NET vNext 包括 MVC,Web API,Web Pages,SignalR 以及 EF 的更新版本。对这些框架所做的主要改进在于 MVC, Web API 和 Web Pages 已经被合并成了单一的编程模型。例如,现在控制器和路由的概念已经统一在了一起。对于同一个 HTTP 请求,你现在可以使用一个控制器来返回 MVC 视图和格式化过的 Web API 响应。
ASP.NET vNext 程序是为云环境设计的。像会话状态和缓存这些服务,会根据程序的运行环境(云环境或普通的主机环境)来调整它们的行为,但是他们是以统一的 API 提供给开发者的。我们在底层使用了依赖注入的方法来让你的程序去适应不同的环境。由于我们修改了底层实现的代码,所以你可以在不修改代码的情况下很容易的将你的程序从内部部署移植到云环境中。
当你修改了 web 应用程序的代码之后,不用再去执行编译的步骤,直接刷新浏览器页面就能查看到修改后的效果。这项对提升生产力很有意义的改进得益于我们对底层 CLR 加载时间的优化以及新的 .NET 编译器平台("Roslyn")。
你可以在下面的图片中看到 ASP.NET vNext 实际工作时的情况。第一张图展示了一个托管在命令行中的 ASP.NET vNext 示例程序,你可以在浏览器中浏览。在 Visual Studio 中做的任何修改都会被自动编译,并且在下一次刷新浏览器的时候执行。该程序使用的就是 .NET vNext 的云端优化过的模式。
你也可以像之前使用 Visual Studio 那样,按 F5 键,Visual Studio 会自动打开一个 web 服务器和浏览器窗口。下面这张图就使用的这种方法,但它的代码和上面的一样。
下面这张图中的程序已经为 .NET vNext 框架重新配置过,并没有使用云端优化过的模式。你只需要设置一下项目的属性,这个程序就可以使用 .NET 框架提供的所有的 API 了。同样,你只需要刷新一下浏览器就可以看到配置后的结果了。
下面这个表格列出了一些我们已经构建了的场景以及这些场景可以使用的地方。
Feature
.NET vNext
.NET vNext (Cloud Optimized)
Cloud Ready
*
*
Modular Design
*
*
Dependency Injection
*
*
Consistent Tracing / Debugging
*
*
Faster Development (browser refresh)
*
*
Open Source
*
*
Full Side by Side (runtime and framework
deployed with application)
*
Faster startup, Lower memory / Higher throughput (best of class)
*
Uses a smaller set of framework libraries
*
Enabled on Mono, on Mac and Linux
*
ASP.NET vNext 将会以开源的形式贡献给 .NET 基金会(.NET Foundation)。大家不用为此感到意外,因为我们早已经把 ASP.NET Web stack 开源了。以后,所有和 ASP.NET vNext 相关的东西将会通过 NuGet 发布,保持开源,并欢迎大家贡献代码。
我们在 TechEd 上对 .NET vNext 和 ASP.NET vNext 所做的介绍只是一个开始,在我们发布最终版之前的这几个月里,我们会和大家分享更多相关内容。我们计划发布一个 pre-release 版本,以便收集大家的反馈。
.NET Framework 其他的一些升级和改进
最近,我们发布了 .NET Framework 4.5.2。 这包括对 ASP.NET,Windows Form 以及其他一些产品的做的显著改进。你现在可以在你的代码中使用 4.5.2 中的一些新特性了。
同时,我们还给 .NET Native 和 Next Generation JIT 添加了新的功能和使用场景。.NET Native 现在除了支持 ARM 和 x64 的程序之外,还支持 32 位的程序。Next Generation JIT 现在支持 Windows 7 及以上的 x64 应用程序。 这些技术都是 .NET vNext 发展道路上的关键部分。期待在未来的几个月中听到更多关于它们的消息。
针对多个平台
为了使程序和库的代码可以更容易的运行在多个平台上,我们已经花了多年的时间在这上面。一开始,我们使 Xamarin 可以使用我们的 PCL 程序集,Xamarin 随之也作出了改变,并将这件事向前推动了一大步。最近一段时间,我们一直与 Xamarin 紧密合作,来使我们的.NET NuGet 包可以更好和 Xamarin 的工具协作,以便可以更容易的把 .NET 程序运行在 iOS 和 Android 上。这还有很长的路要走,但是,我们已经取得了很多经验,并且会继续改进它。
在 TechEd,我们发布了一个新的可移植的统计分析工具——ApiPort。它为你提供了两项主要的数据:你代码可以运行的平台以及阻止你代码运行在其他平台上的相关依赖。
命令行工具为程序可移植性的统计分析结果生成了一个 Excel 格式的报告,该报告提供了两种视图方便你的查看。它为指定的平台提供了一个高级的、以颜色区分开来的视图,同时它还提供了一个详细的列表,列出了你的代码中所有类型的成员在各平台中的支持情况。考虑到报告是一个 Excel 文件,你可以很容易的过滤这个列表,构建数据透视表以及做进一步的分析。
下面的图片展示了可移植性分析结果的高级视图。只显示了一个程序集,但实际上是有多个的。你可以下载 可移植性分析样例 来看一下它的原始数据。
该工具还有另一个功能,所有和依赖相关的数据(不包括程序集)会被上传到一个由 .NET 团队维护的 Azure 服务上。该工具上传的数据只是你代码所依赖的程序集和 API 的列表。我们不会记录数据的来源和使用者的信息,也不会上传你的代码和二进制文件。我们只是想要知道我们还需要为不同的平台提供些什么功能,以便使代码可以更容易的跨平台。
如果你发现很难转换至一个特定的平台,请投票选出你想要为运行你的 app 和 libraries 的特定平台上的工具集所附加的 APIs。在整个目录运行工具集是一件很容易的事。
首次释出的版本可能缺乏一些特性,目前我们正努力为它添加支持 。Xamarin/Mono 平台目前还缺乏一些工具集。还没有考虑引入 NuGet packages ,它可以使其它平台同样可以利用 .NET Framework APIs,可以把它们统计为缺失的 APIs。
获得 ApiPort tool – 这个工具很快就会发布。
你很可能已经听说过 Microsoft 是一个“services first” 和“devices first”的公司。这之间的关联便是 client libraries,它使得 apps 访问 Microsoft services 变得很容易。尽管用于 Microsoft Service 的 Client Libraries 并非最新的概念,但我们目前努力为它提供多平台支持。我们从提供 Office 365 services 开始,随着时间的推移我们打算添加更多的服务支持。
在 TechEd 在,我们发布了一个用于 Office 365、.NET 和 JavaScript 的预览版的 client libraries。你可以在 Office Developer Blog 上阅读最新的 Office 365 client libraries 授权声明。.NET Client libraries 支持 WPF、 Windows Forms、Windows Store、Xamarin.iOS、Xamarin.Android 和 ASP.NET apps 以及 Portable Class Libraries,通过 NuGet 传递消息。
我们也提供了用 Visual Studio 增加 libraries 到你的 apps 中的集成体验。这些服务需要 apps 注册,权限选择和一个特殊平台用户验证过程。你也需要增加下正确的 client libraries 至你的 apps。 Visual Studio 会管理好你的一切数据,作为联系人服务管理的一部分,如下所示。
你可以从 Office Developer blog 学习如何利用这项特性。这个项目我们使用 StackOverflow 作为社区论坛,在 Office365APIs tag 上。请告诉我们你对 client libraries 和新版本 Visual Studio 集成的看法。敬请注意 Office services 的用途,预览版本目前还不支持商业 apps。
在 .NET 团队,我们非常乐意分享下一代的 .NET 技术。正如你从公告和我们在大会上发布的版本中看到的。我们组合了一些重要的技术、特性和应用场景,这些将成为 .NET vNext 的一部分,我们下一步的主要目标释出 .NET Framework 的源码。在这篇公告中,我们主要聚集于 ASP.NET vNext,下一代的 Web 技术和服务平台。
对 .NET vNext 而言,我们将在宣布重大版本之前广泛讨论主要的特性和寻求更多的反馈。我们一直积极与相应的专家和爱好者通过预览版和预发行版来沟通观点和发展趋势。这最终被证明是一个伟大的创举。反馈之多令人难以置信。非常感谢各位参与我们的 CTPs,开发者预览版,预发行版和其它我们收集反馈的项目。我们也在博客中收到了相当优质的反馈,这些反馈非常有用。敬请期待数月内的多平台的预览版,特别是 ASP.NET vNex,这将是一个历史性的时刻。
在 TechEd 上,接下来的幻灯片中,你可以看到这些技术是如何集成到单一的 NET Framework 版本中。开源也是我们计划中非常重要的一部分,你可以在 the .NET Foundation 上看到我们 ASP.NET vNext 的贡献计划。 .NET 的未来是非常光明的。