ASP.NET Core 进程外(out-of-process)托管(7)《从零开始学ASP.NET CORE MVC》

本文出自《从零开始学ASP.NET CORE MVC》 推荐文章:ASP.NET Core 进程内(InProcess)托管

ASP.NET Core 进程内(InProcess)托管

我们先简单回顾下 ASP.NET Core 中,要配置InProcess的服务器,

需要在项目文件中添加< AspNetCoreHostingModel >元素,其值为InProcess

< AspNetCoreHostingModel > InProcess </ AspNetCoreHostingModel >

使用InProcess托管,应用程序托管在IIS工作进程(w3wp.exe或iisexpress.exe)中。 使用InProcess托管,只有一个Web服务器,它是承载我们的应用程序的IIS服务器。

进程内托管图示

ASP.NET Core 进程外(out-of-process)托管

有两种方法可以配置进程外托管 :

  • 方法一:将< AspNetCoreHostingModel >元素添加到应用程序的项目文件中,其值为OutOfProcess
< AspNetCoreHostingModel > OutOfProcess </ AspNetCoreHostingModel >
  • 方法二:默认为OutOfProcess托管。因此,如果我们 从项目文件中删除 < AspNetCoreHostingModel >元素,默认情况下ASP.NET Core 将使用OutOfProcess托管。

进程外(out-of-Process)托管

  • 有2个Web服务器 ,内部Web服务器和外部Web服务器。
  • 内部Web服务器是Kestrel, 外部Web服务器可以是IIS,Nginx或Apache。在上节课中我们讨论了什么是Kestrel

根据您运行asp.net Core 应用程序的方式的不同,可能会,也可能不会使用外部Web服务器。

Kestrel 是嵌入在 asp. net Core 应用程序中的跨平台 web 服务器。使用进程外(out-of-Process)托管, Kestrel 可通过以下两种方式来进行使用:

Kestrel 可以用作面向互联网的 web 服务器, 直接处理传入的 HTTP 请求。 在此模型中, 我们不使用外部 web 服务器。只使用 Kestrel, 它作为服务器可以自主面向互联网, 直接处理传入的 HTTP 请求。 当我们使用. net Core CLI 运行 asp. net Core 应用程序时, Kestrel 是唯一用于处理和处理传入 HTTP 请求的 web 服务器。

kestrel直面互联网

Kestrel 还可以与反向代理服务器 (如 IIS、Nginx 或 Apache) 结合使用。

配合方向代理

来个讨论

如果Kestrel可以单独用作Web服务器,为什么我们需要一个反向代理服务器?

因为Kestrel使用 "进程外(out-of-process)托管", 结合反向代理服务器是一个不错的选择, 因为它提供了额外的配置和安全性层。它可能会更好地与现有基础设施集成。它还可用于负载平衡。

因此, 在使用反向代理服务器的情况下, 它将接收来自网络的传入 HTTP 请求, 并将其转发到 Kestrel 服务器进行处理。在处理请求时, Kestrel 服务器将响应发送到反向代理服务器, 然后反向代理服务器最终通过网络将响应发送到请求的客户端。

在后面的视频课程中,我们将学习如何将ASP.NET Core应用程序部署到IIS并使用IIS作为反向代理服务器。当我们直接从Visual Studio运行asp.net Core 应用程序时,它默认使用IIS Express。 由于我们已将应用程序配置为使用进程外托管,所以当前情况下,IIS Express 已经在充当反向代理服务器了。

IIS Express接收传入的HTTP请求并将其转发给Kestrel进行处理。Kestrel处理请求并将响应发送到IIS Express。IIS Express反过来将该响应发送到浏览器。

使用进程外托管无论您是否使用反向代理服务器,Kestrel服务器都是作为托管应用程序的服务器同时处理请求的,也就是我们最开始说的自托管。 如果使用反向代理服务器接收传入的HTTP请求并将其转发到Kestrel服务器。同样,它从Kestrel服务器获取响应并将其发送到客户端。因此托管应用程序的进程名称是dotnet.exe

使用以下代码获取进程名称

我们来操作一波,给大家演示看看。记住下面这行代码,是个知识点

            System.Diagnostics.Process.GetCurrentProcess().ProcessName;

当我们使用.NET Core CLI运行asp.net Core 项目时,默认情况下它会忽略我们在.csproj文件中指定的托管设置。因此项目文件中的```AspNetCoreHostingModel``标签下的值是被忽略了的。 无论您指定的值(InProcess或OutOfProcess)如何,它始终都是OutOfProcess托管,都是通过Kestrel托管应用程序,同时处理http请求。

一个常见问题

我们可以在不使用内置的Kestrel Web服务器的情况下运行asp.net Core 应用程序吗?

答案是肯定可以的,你要相信.NET Core的开发团队。如果我们使用InProcess托管,则应用程序将托管在IIS工作进程(w3wp.exe或iisexpress.exe)中。

知识点:Kestrel不与InProcess(进程内)托管一起使用

代理服务器: 泛指IIS,Nginx或Apache等等

所以.net core 有多优秀大家知道了吧。欢迎留言互动~

原文发布于微信公众号 - 角落的白板报(jiaoluodebaibanbao)

原文发表时间:2019-04-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券