How to host multiple .NET Core apps under same url

2020-03-01 16:28发布

问题:

I am building a few web sites in asp.net core (multiple user interface applications and a web api app). They all work together, utilising the web api. For the purpose of my question we'll call them App1, App2 and App3. I am hosting my websites in IIS.

Typically, in the old .net Framework (4.5.1), I would have one website in IIS, with multiple web apps to host my multiple applications. Like so:

  • WebSite1 - running on port 443

    • App1

    • App2

    • App3

If the website (WebSite1) runs on port 443 (using the SSL cert), that means all apps are accessible via one domain url as follows:

  • https://www.myapp.com/App1/

  • https://www.myapp.com/App2/

  • https://www.myapp.com/App3/

With different app names at the end of the url to identify them.

When hosting the new asp.NET Core applications, I host in IIS as well, and following the documentation for asp.NET Core web site deployment, I host each .NET Core web app in a different site within IIS.

As I have one domain name for all my sites, for example, https://www.example.com (I'm using an SSL cert), I have to give the other websites different ports. So I end up with something like this:

  • WebSite1 - running on port 443

  • WebSite2 - running on port 444

  • WebSite3 - running on port 445

All of these apps are then accessible via these domain name urls:

  • https://www.example.com/ or https://www.example.com:443/

  • https://www.example.com:444/

  • https://www.example.com:445/

How do I host asp.NET Core applications all under one website as different "Applications", meaning they resolve to the same domain name url (https://www.example.com and the forward slash app name identifies which app we want)? OR alternatively, how do I take what I have configured now with the ports and route them all so App1 is default for example.com/, App 2 is example.com/app2/, and App 3 is example.com/app3/?

Am I looking at this .NET Core deployment completely the wrong way?

Thanks in advance for any pointers!

回答1:

You could use a reverse proxy for serving multiple ASP Net Core application on the same domain.
Using IIS I'm not quite sure but you need to install URL Rewrite and then follow the documentation provided by Microsoft (also this one should be helpful).
You can also use nginx using location and proxy_pass as follow:

...
Some nginx Configuration 
location /App1 {
        proxy_pass http://127.0.0.1:443;
    }
location /App2 {
        proxy_pass http://127.0.0.1:444;
    }
location /App3 {
        proxy_pass http://127.0.0.1:445;
    }
Other configurations...

And then, each time you want add another ASP Net application to your domain you'll need to add another location, run the application on a different point and restart nginx.



回答2:

You don't need to create a site for each app, you can host it as before, as web applications inside one site. The only thing you need to do is select unmanaged app pool for your .Net Core applications, that's it. So this works: https://domain/app1 and https://domain/app2 and you only need 1 certificate for a web server

Alternatively, you can create site for each app, then you need a sub-domain for each app, like https://app1.domain and like https://app2.domain In this case all sub-domains must point to the same IP (if your server only have one) and you need to set up bindings for each site\app to it's domain. You should bind all sites to the same port (443 or 80).

For SSL in multiple sites configuration if you have IIS 7 you need to have a wildcard certificate. In IIS 8 and above you can use Server name indication feature and have a separate certificate for each site, however I recommend you to use wildcard certificate as well since SNI is new and might not be supported by some browsers

In both cases you need to set up a Windows Server Hosting from here Microsoft's download center



回答3:

For IIS, you can use Application Request Routing (ARR) which combine with URL rewrite module to routing request into each the association between URL port. It is used to build a similar proxy like Nginx and point to an appropriate port following each pattern of the URL. You can see a sample with ARR below:

https://www.iis.net/learn/extensions/url-rewrite-module/reverse-proxy-with-url-rewrite-v2-and-application-request-routing



回答4:

Try it: In file Web.config each application has a different name: <add name="herenewappname" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />



回答5:

I got this working using the advice for Sub-applications here: https://docs.microsoft.com/en-us/aspnet/core/host-and-deploy/iis/?view=aspnetcore-2.2#sub-applications.

Here's the meaty part, in case the link dies:

To host an ASP.NET Core app as a sub-app under another ASP.NET Core app:

1.Establish an app pool for the sub-app. Set the .NET CLR Version to No Managed Code because the Core Common Language Runtime (CoreCLR) for .NET Core is booted to host the app in the worker process, not the desktop CLR (.NET CLR).

2.Add the root site in IIS Manager with the sub-app in a folder under the root site.

3.Right-click the sub-app folder in IIS Manager and select Convert to Application.

4.In the Add Application dialog, use the Select button for the Application Pool to assign the app pool that you created for the sub-app. Select OK.

As a bonus, my main application is legacy Web Forms and my sub-application is exciting new .NET Core functionality.

Happy days.