When hosting .NET core web app in IIS, what are the pros and cons between "In process" and "out of process" hosting model
Asked Answered
S

2

13

When hosting a .NET core web application in IIS, you can choose between in process and out of process hosting model.

Except for better performance by using in process, what are some pros and cons between "In process" and "out of process" hosting model?

And is one better than the other for test/dev vs production?

I would imagine that a "out of process" hosting model is easier to attach a debugger to.

Sycophant answered 13/12, 2019 at 10:32 Comment(1)
When you can use in-process, use it. I wonder why you think out-of-proccess is easier to attach a debugger to, as in both cases you just find the right process to attach.Dibru
E
14

Since ASP.NET Core 3.0, "in process" is the default, see this Microsoft page. When hosting the web application on IIS.ASP.NET Core Module forwards the requests to IIS HTTP Server (IISHttpServer). The IIS HTTP Server is a server that runs in-process with IIS.

If you used Out-Of-Process hosting model, IIS HTTP Server won't be used. Instead Kestrel web server is used to process your requests.

From Rick's blog:

"In process" provides better performance and is generally less resource intensive as it avoids the extra network hop between IIS and Kestrel and maintaining an additional process on the machine that needs to be monitored.

There are a few cases when OutOfProcess hosting might be desirable, such as for trouble shooting and debugging a failing server (you can run with console logging enabled for example) or if you want to be 100% compatible between different deployments of the same application, whether it's on Windows or Linux, since Kestrel is the primary mechanism used to handle HTTP requests on all platforms.

With the InProcess model you're not using Kestrel, but rather a custom IISHttpServer implementation that directly interfaces with IIS's request pipeline.

But for most intents and purposes I think running InProcess on IIS is the way to go, unless you have a very specific need to require Kestrel and OutOfProcess hosting.

Excitor answered 16/12, 2019 at 2:10 Comment(0)
F
0

One thing to consider is out-of-process hosting will allow the Windows malware scanning APIs (AMSI) to be effective.

By default anything running under the IIS Process is excluded.

You can configure your malware scanner to include the IIS process but it is generally excluded for a good reason.

Something we discovered the hard way when trying to perform malware scans on incoming files.

Friction answered 13/8, 2024 at 11:24 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.