Skip to content

Multi-Tenancy in Raydium

In Raydium's multi-tenant architecture, each tenant operates as an independent entity within a shared framework, ensuring maximum flexibility and customization. A key aspect of this architecture is that each tenant has its own dedicated database and the ability to utilize its own configuration options settings and .env file. This setup provides several advantages, including data isolation, security, and tailored experiences for each tenant.

Tenant-Specific Databases

Isolation and Security

Each tenant having its own database means that the data for each tenant is completely isolated from others. This isolation enhances security by ensuring that no tenant can access the data of another, intentionally or accidentally.

Customization and Scalability

Dedicated databases allow for customization at the data structure level, enabling tenants to have unique schemas that best fit their specific needs. It also aids in scaling, as each database can be scaled independently based on the tenant's requirements.

Maintenance and Backup

With separate databases, maintenance operations (like backups, updates, or optimizations) can be performed on a per-tenant basis, reducing the risk of affecting other tenants and enabling more tailored maintenance schedules.

Tenant-Specific Configurations

Flexibility

Tenants can define their own app.php configuration options within their designated configuration directories (e.g., config/{tenant_id}/app.php). This flexibility allows for tenant-specific settings like themes, plugins, performance optimizations, and feature toggles.

In multi-tenant mode customizing some configuration options may be limited.

Independence

Tenants can operate independently from each other, making changes to their configurations without the risk of impacting other tenants. This independence is crucial for businesses that cater to diverse clients with varying requirements.

Streamlined Management

While tenants have the freedom to customize their configurations, central policies and updates can still be enforced at the framework level, ensuring consistency where necessary while allowing for customization.

Implementation Considerations

Unique Tenant Identification

Each tenant is typically identified by a unique identifier (UUID), which is used to associate the correct configuration settings for each tenant.

Configuration Precedence

The Raydium framework ensures that tenant-specific configuration options take precedence over global configuration options, allowing for granular control at the tenant level.

Environment Variables

Tenants also utilize environment variables defined in their .env environment files for sensitive information, ensuring that configuration files remain secure and version-controllable.

Multi-tenancy in Raydium offers a powerful paradigm for managing multiple sites with efficiency and security. By providing each tenant with its own database and the ability to use custom configuration options, Raydium ensures that tenants can enjoy a tailored, secure, and isolated environment.