如何用简单的词语和用法解释Katana和OWIN?

时间:2013-12-11 16:05:20

标签: asp.net iis owin katana

我读过很多关于OWIN和Katana项目的文章,但我无法全面了解它。

对于使用ASP.NET的普通Web开发人员:

  1. OWIN究竟是什么,它解决了什么问题(简单来说)。它与IIS的关系是什么?
  2. OWIN会替换IIS吗?如果没有,OWIN在什么情况下最适合?
  3. OWIN如何帮助我完成日常工作?
  4. OWIN如何帮助我完成自我改善项目?

4 个答案:

答案 0 :(得分:384)

关于上述评论,OWIN不是一个框架。 OWIN是关于如何构建Web服务器和Web应用程序的规范,以便将它们分离并允许ASP.NET应用程序移动到以前不支持的环境。

在OWIN之前,在构建ASP.NET应用程序时,由于对System.Web程序集的严重依赖,您本身就绑定到了IIS。

System.Web是自ASP(非.NET版本)以来一直存在的内容,并且内部包含许多您可能不需要的东西(例如Web窗体或URL授权),默认情况下每个都运行请求,因此消耗资源并使ASP.NET应用程序通常比其对应程序(例如Node.js)慢很多。

OWIN本身没有任何工具,库或其他任何东西。这只是一个规范。

另一方面,Katana是一个完全开发的框架,用于在当前的ASP.NET框架和OWIN规范之间架起桥梁。目前,Katana已经成功地将以下ASP.NET框架改编为OWIN:

  • Web API
  • Signal R

ASP.NET MVC和Web窗体仍然只能通过System.Web运行,从长远来看,还有计划将它们分离。

另一方面,IIS是Web服务器的良好,资源丰富的主机。使用IIS的整个ASP.NET性能问题仅限于System.Web。直到最近一次,在决定如何托管您的Web服务器时,您有两种选择:

  • IIS
  • 自主机

因此,如果您想要一个表演,那么您可以选择自选主机。如果你想要IIS提供很多开箱即用的功能,你可以选择IIS,但是你会失去性能。

现在,有一个第三个选项,一个名为Helios(当前代号)的Microsoft库,它打算将System.Web移除,并允许您在更多"上使用IIS。清洁器"方式,没有任何不必要的库或模块。 Helios现在处于预发布版本,正在等待更多社区反馈,以使其完全支持Microsoft产品。

希望这个解释能够更好地为您澄清事情。

EDIT(2014年9月):

随着ASP.NET vNext正在开发中,Katana正在慢慢退休。 3.0版很可能是Katana作为独立框架的最后一个主要版本。

然而,Katana引入的所有概念都被集成到ASP.NET vNext中,这意味着编程模型将完全相同。来自David Fowler(ASP.NET vNext的架构师)的forum post引用:

  

vNext是Katana的继承者(这就是他们看起来如此相似的原因)。   Katana是从System.Web脱离更多的开始   Web堆栈的模块化组件。您可以将vNext视为   继续这项工作,但更进一步(新的CLR,新项目   系统,新的http抽象)。

     

今天Katana中存在的一切都将进入vNext。

编辑(2015年2月):

ASP.NET vNext现在称为ASP.NET 5,它将构建在.NET Core 5之上..NET Core 5是.NET Framework的轻量级因子版本,旨在支持ASP.NET 5的目标和.NET Native。但是,.NET 5 4.6也将支持ASP.NET 5,它应该与.NET Core 5一起提供.ASP.NET 5和.NET Core 5都将在MIT下获得许可并接受社区贡献。

编辑(2015年5月):

此外,ASP.NET Web API品牌将停止使用,但它的技术将成为新的ASP.NET MVC 6的基础。以前的ASP.NET MVC版本是通过实现IHttpHandler构建的,IHttpHandler是{ {1}}。 ASP.NET MVC 6消除了这种依赖性,使其可以移植到各种平台和Web服务器上。

编辑(2016年5月):

ASP.NET 5将正式重命名为ASP.NET Core,从Release Candidate 2开始,计划很快发布。同样适用于将重命名为Entity Framework Core的Entity Framework 7。有关官方公告及其背后原因的更多信息,请参阅Scott Hanselman的博客文章: ASP.NET 5 is dead - Introducing ASP.NET Core 1.0 and .NET Core 1.0

编辑(2016年5月):

随着Release Candidate 2的发布, ASP.NET Core已被修改,以便未来的Web应用程序实际上只是用于处理传入HTTP请求的.NET Core控制台应用程序。这一概念使ASP.NET Core更加符合Microsoft在微服务架构支持及其通过Azure Service Fabric实现的方法。有关更多信息,请访问官方博客文章: Announcing ASP.NET Core RC2

答案 1 :(得分:71)

如果我必须为自己定义OWIN,那就是:“来自Ruby和Node.js Web开发社区的最佳创意,来到.NET”

但这对任何ASP.NET开发人员都无济于事。我自己的定义将是:

OWIN定义了.NET Web服务器和Web应用程序之间的标准接口。 OWIN接口的目标是解耦服务器和应用程序 如果我必须回答你提出的问题,那么它就是:

  1. OWIN是一种接口规范。它将Web应用程序与IIS分离。

  2. 如果您使用现成的组件(这是Katana的组件),那么与旧的ASP.NET相比,应用程序功能的某些部分更容易实现。与第三方身份提供商(Facebook,Twitter)进行身份验证就是其中的一个例子。

  3. OWIN本质上是最佳实践的集合,已在Web开发社区中得到验证。它展示了一种实现对可扩展性非常开放的Web应用程序的方法。由于每个Web开发人员都应该始终站在新技术的最前沿,这是与整个Web开发社区保持同步的一种方式,而不仅仅是.NET。如果您学习OWIN,那么学习其他Web开发框架(例如Express for node.js或Rack for Ruby)会更容易,因为他们使用的实践是相似的。

答案 2 :(得分:57)

我会尝试从实际的角度来介绍它。

Katana是项目名称to implement OWIN in Microsoft

OWIN究竟是什么以及它解决了什么问题(简单来说)。它与IIS的关系是什么? OWIN(Open Web Interface for .NET)是标准(OWIN Specification),Katana是.NET库,你可以get nuget from here。 OWIN和Katana在网络上成了一些同义词 在OWIN之前,您唯一的选择是使用OWIN IIS,您可以使用任何其他应用程序(具有入口点)作为Web服务器。

OWIN会替换IIS吗?如果没有,OWIN在什么情况下最适合?
不,它不会取代IIS,您可以使用OWIN和IIS there's Microsoft.Owin.Host.SystemWeb nuget for that。如果您想要优化/更改在IIS中处理它的方式,或者您想要创建自定义Web服务器,最好不要使用Windows Forms Application。

OWIN如何帮助我完成日常工作?
它可以降低您的服务器运行成本,因为您的Web服务器不再需要在IIS(Windows)上运行(Windows服务器比基于Unix的服务器更昂贵,您可以在Linux下的Mono下的控制台应用程序上运行它)。

OWIN如何帮助我完成自我改善项目?
学习Microsoft.Owin(和其他相关的OWIN库)将提高您对客户端和Web服务器之间的HTTP通信如何工作的了解。

Good read if you want to understand more on what Katana and OWIN is.

答案 3 :(得分:8)

什么是OWIN?

OWIN代表Open Web Interface for .NET。 OWIN是一个规范,描述了ASP.NET MVC等Web开发框架应如何与Web服务器交互。 OWIN的目标是通过引入抽象层将Web应用程序与Web服务器分离。这种抽象使您可以在支持OWIN的所有Web服务器上运行相同的应用程序。此外,它简化了整个系统,因为抽象层可以提供轻量级基础架构来托管应用程序。 IIS为Web应用程序提供了丰富的功能。但是,Web应用程序可能不需要所有这些功能。它们具有最小的HTTP处理能力可能就足够了。 OWIN兼容主机可以为这些应用程序提供这样的托管环境。此外,您可以定义在请求处理期间使用的模块管道。 OWIN管道是一系列OWIN兼容组件,请求通过这些组件。

什么是Katana?

Katana是Microsoft使用OWIN规范构建的一组组件。其中一些组件包括Web API,ASP.NET Identity和SignalR。

以上是CodeGuru文章摘录:http://www.codeguru.com/csharp/.net/net_asp/overview-of-owin-and-katana.htm