首页
/ 多租户Laravel项目教程

多租户Laravel项目教程

2026-01-15 17:54:34作者:仰钰奇

1. 项目介绍

tenancy/multi-tenant 是一个用于在同一 Laravel 安装中运行多个网站的开源项目。它通过将租户特定的数据分离,实现了完全独立的多域名设置。该项目适用于希望为不同客户重复使用功能的营销公司,或构建下一个软件即服务(SaaS)的初创公司。

主要特点:

  • 集成 Laravel 框架:与 Laravel 无缝集成,提供事件驱动和可扩展的架构。
  • Web 服务器集成:可选的 Web 服务器集成,支持 Apache 和 Nginx。
  • 租户特定配置:允许添加租户特定的配置、代码和路由。
  • 数据库分离方法:支持多种数据库分离方法,包括系统数据库和分离的租户数据库、表前缀等。

2. 项目快速启动

安装

首先,通过 Composer 安装 tenancy/multi-tenant

composer require hyn/multi-tenant

自动服务注册

使用自动发现功能,tenancy 包将被 Laravel 自动检测到:

{
    "extra": {
        "laravel": {
            "dont-discover": [
                "hyn/multi-tenant"
            ]
        }
    }
}

手动服务注册

如果需要手动集成,可以在 config/app.php 中注册服务提供者:

'providers' => [
    // Hyn multi tenancy
    Hyn\Tenancy\Providers\TenancyProvider::class,
    // Hyn multi tenancy webserver integration
    Hyn\Tenancy\Providers\WebserverProvider::class,
]

部署配置

发布配置和迁移文件:

php artisan vendor:publish --tag=tenancy

打开 config/tenancy.phpconfig/webserver.php 文件进行配置。确保系统连接已在 database.php 中配置。

运行迁移:

php artisan migrate --database=system

3. 应用案例和最佳实践

应用案例

  • SaaS 平台:为不同客户提供独立的应用实例,每个实例拥有独立的数据库和配置。
  • 多品牌网站:在同一 Laravel 安装中运行多个品牌网站,每个品牌拥有独立的域名和数据。

最佳实践

  • 数据库分离:根据业务需求选择合适的数据库分离方法,确保数据安全性和性能。
  • 租户特定配置:利用租户特定配置功能,为不同租户提供定制化的功能和界面。
  • 事件驱动架构:通过事件驱动架构,实现模块间的松耦合,提高系统的可扩展性。

4. 典型生态项目

  • Laravel Horizon:用于管理 Laravel 队列的分布式后台任务系统,与 tenancy/multi-tenant 结合使用,可以为每个租户提供独立的队列管理。
  • Laravel Telescope:用于监控和调试 Laravel 应用的工具,结合 tenancy/multi-tenant,可以为每个租户提供独立的监控和调试功能。
  • Laravel Nova:用于构建管理面板的工具,结合 tenancy/multi-tenant,可以为每个租户提供独立的管理面板。

通过以上模块的介绍,您可以快速了解并上手 tenancy/multi-tenant 项目,并结合实际应用场景进行最佳实践。

登录后查看全文
热门项目推荐
相关项目推荐