Skip to content

Multitenant ASP.NET Core application to serve as a starting point for real multitenant applications

Notifications You must be signed in to change notification settings

gpeipman/AspNetCoreMultitenant

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Multi-tenant ASP.NET Core

This is demo project for my Multi-tenant ASP.NET Core presentation. It demonstrates multi-tenant solutions I have worked out for ASP.NET Core. I'm using the same demo also for presentations. Solutions provided here are not absolute truth. There are cases when something different is needed and then the code here serves as a good starting point.

Features

There are multiple features and solutions demonstrated in demo application:

Setting every thing up

To demonstrate multi-tenant features I have built I'm using SQL Server LocalDB and MySQL databases. SQL Server LocalDB uses integrated security. For MySQL some user account is needed to access database. Those who plan to run this example on Linux must use some Linux version of SQL Server or SQL Server running on some other machine.

There are two web applications in the solution:

  • AspNetCoreMultitenant.Web - safe multitenant web application to use as an example and starting point
  • AspNetCoreMultitenant.WebDangerous - dangerous approach to shared resources (shared database tables)

AspNetCoreMultitenant.Web defines three tenants:

  • bigcorp - uses dedicated MySQL database
  • sme1 - uses SQL Server database
  • sme2 - uses SQL Server database

AspNetCoreMultitenant.WebDangerous defines two tenants:

  • sme1 - uses same SQL Server database as sme2
  • sme2 - uses same SQL Server database as sme1

There are also some host name mappings needed to run this demo on local machine:

  • 127.0.0.1 bigcorp
  • 127.0.0.1 sme1
  • 127.0.0.1 sme2

Web application uses port 5000 and it must be added to URL of all tenants:

Dangerous web application uses port 5001 and it must be added to URL of all tenants:

When using public server to host this application make sure you turn on HTTPS in application startup.

Concepts

This solution has some important concepts to know:

  • Tenant source - class that knows how to read tenant definitions from tenants store
  • Tenant provider - class that knows how to find current tenant
  • Dynamic cache key provider - class that provides EF Core with caching keys for DbContext model
  • Missing tenant middleware - ASP.NET Core request pipeline middleware that acts when tenant is not found

About

Multitenant ASP.NET Core application to serve as a starting point for real multitenant applications

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published