我读过很多关于OWIN和Katana项目的文章,但我无法全面了解它。
对于使用ASP.NET的普通Web开发人员:
答案 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:ASP.NET MVC和Web窗体仍然只能通过System.Web运行,从长远来看,还有计划将它们分离。
另一方面,IIS是Web服务器的良好,资源丰富的主机。使用IIS的整个ASP.NET性能问题仅限于System.Web
。直到最近一次,在决定如何托管您的Web服务器时,您有两种选择:
因此,如果您想要一个表演,那么您可以选择自选主机。如果你想要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接口的目标是解耦服务器和应用程序 如果我必须回答你提出的问题,那么它就是:
OWIN是一种接口规范。它将Web应用程序与IIS分离。
如果您使用现成的组件(这是Katana的组件),那么与旧的ASP.NET相比,应用程序功能的某些部分更容易实现。与第三方身份提供商(Facebook,Twitter)进行身份验证就是其中的一个例子。
答案 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