Laravel comes with route caching out of the box. By default
all routes are cached, which means that the application will only load the routes once. This is great if your routes
are static. However, if you're using dynamic routes, for example different routes for different tenants, you'll need
to keep a separate route cache for each tenant.
The Spatie\Multitenancy\Tasks\SwitchRouteCacheTask
can switch the configured APP_ROUTES_CACHE
environment variable to a tenant specific value.
To use this task, you should uncomment it in the switch_tenant_tasks
section of the multitenancy
config file.
'switch_tenant_tasks' => [
\Spatie\Multitenancy\Tasks\SwitchRouteCacheTask::class,
],
##A route cache for each tenant
In the default scenario, all tenants have different routes. The package creates a route cache file for each tenant: bootstrap/cache/routes-v7-tenant-{$tenant->id}.php
.
Most importantly, you should use php artisan tenant:artisan route:cache
to cache your routes instead of Laravel's default route:cache
command. This will make sure a different route cache file is generated for each tenant.
##Route cache shared across the tenants
It's the scenario where all tenants use the same routes. The package creates a shared route cache file for all tenants: bootstrap/cache/routes-v7-tenants.php
.
To enable the feature you should set to true
the shared_routes_cache
section of the multitenancy
config file.
'shared_routes_cache' => true,
Most importantly, you should use php artisan tenant:artisan route:cache --tenant=YOUR-TENANT-ID
to cache your routes instead of Laravel's default route:cache
command. This will make sure a different route cache file is generated for each tenant.