Skip to content

Rubenmp/multitenant-web-store

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 

Repository files navigation

Multitenant web store

This project is my Master's Thesis at Universidad de Granada (Doble Grado en Ingeniería Informática y Matemáticas). There is a study of multi-tenancy in Cloud computing, its implications and trade-offs. Multi-tenancy is a property of a system where multiple customers, so-called tenants, transparently share the system’s resources.

A minimalist multi-tenant web store called MW-Store is implemented to study the characteristics of this type of system. The super user of this store can create tenants (in this case, organizations with e-commerce) from its admin console: Tenant management from super user

It is relevant to highlight that each tenant's data is logically separated (although all tenants' data share a database). A business can not access the administrative information of other businesses. The super user manages the admins of each tenant: Admin management from super user

At this point, the registered business will control its online e-commerce. Business admins can create/update/delete products from their back office: Admin product management

Then, the end users of each e-commerce can order the products: User order product

And an order history is stored. Each client will have access to its orders, but tenant administrators can query all the order history: Admin order history view

A Colored Petri Net (CPN), a mathematical model of the system, is included to extract conclusions about their properties. It is possible to detect the effective conflicts of a system and adapt the design for better scalability (or even better, elasticity). Modelling reactive systems with CPNs have several advantages explained in the dissertation. Here is the final CPN model of the MW-Store shown with the CPN Tools interface: MWS CPN

The implications of mathematical models of programs are huge. These models are not limited to demonstrating static and dynamic system properties. They can be used as a starting point for software observability, helping to solve real-world bugs in complex software.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published