Code review at scale is broken. Here’s how Augment Code is fixing it.

Lada Cache

spiritix/lada-cache image

Lada Cache stats

Downloads
284.2K
Stars
513
Open Issues
12
Forks
66

View on GitHub →

A Redis based, automated and scalable database caching layer for Laravel

Lada Cache

A Redis based, fully automated and scalable database cache layer for Laravel

Contributors wanted! Have a look at the open issues and send me an email if you are interested in a quick introduction via Hangouts.

Table of Contents

For further information on how this library works and how to debug it please have a look at the Wiki.

Features

  • Automatically caches all database queries
  • Intelligent cache invalidation with high granularity
  • Works with existing code, no changes required after setup
  • Possibility to cache only specific models or exclude some models
  • Makes use of Laravel Redis (supports clustering)

Version Compatibility

Laravel PHP Lada Cache
5.1-5.6 5.6.4+ 2.x
5.7-5.8 7.1+ 3.x
6.x 7.2+ 4.x
7.x 7.2+ 5.x
8.x 7.3+ 5.x
9.x 8.0+ 5.x

Performance

The performance gain achieved by using Lada Cache varies between 5% and 95%. It heavily depends on the quantity and complexity of your queries. The more (redundant) queries per request your application fires and the more complex they are, the bigger the performance gain will be. Another important factor to consider is the amount of data returned by your queries, if a query returns 500MB of data, Lada Cache won't make it faster at all. Based on experience, the performance gain in a typical Laravel web application is around 10-30%.

Other than the performance gain, an essential reason to use Lada Cache is the reduced the load on the database servers. Depending on your infrastructure, this may result in reasonable lower cost and introduce new possibilities to scale up your application.

Why?

A lot of web applications make heavy use of the database. Especially using an ORM like Eloquent, queries repeat often and are not always very efficient. One of the most common solutions for this problem is caching the database queries.

Most RDBMS provide internal cache layers (for example Mysql Query Cache). Unfortunately, these caching systems have some very serious limitations:

  • They do not cache queries over multiple tables (e.g. if the queries are using joins)
  • The invalidation granularity is very low (if a single row changes, the entire table gets removed from the cache)
  • They are not distributed, if you have multiple database servers the cache will be created on all of them
  • They are not scalable

Laravel, on the other hand, provides the possibility to cache particular queries manually. The problem is that it doesn't invalidate the cached queries automatically, you'll need to let them expire after a certain time or invalidate them manually on all places where the affected data might be changed.

This library provides a solution for all of the mentioned problems. Install, scale up and lean back.

Why only Redis?

As you may have discovered while looking at the source code, this library is built directly on top of Laravel Redis instead of Laravel Cache, which would make more sense from a general point of view. However, there are several important reasons behind this decision:

  • Storage must be in-memory (wouldn't make much sense otherwise)
  • Storage must be easily scalable
  • Storage must support tags (Laravel Cache does support tags, but the implementation is very bad and slow)

If you still want to use another storage backend, please feel free to contribute.

Requirements

Installation

Lada Cache can be installed via Composer by requiring the spiritix/lada-cache package in your project's composer.json. Or simply run this command:

composer require spiritix/lada-cache

The Lada Cache service provider will automatically be installed using Package Discovery.

Finally, all your models must include the Spiritix\LadaCache\Database\LadaCacheTrait trait. It's a good practice to create a base model class which includes the trait and then gets extended by all your models.

class Car extends \Illuminate\Database\Eloquent\Model {
 
use \Spiritix\LadaCache\Database\LadaCacheTrait;
 
// ...
}

Don't try to only have specific models including the Lada Cache trait, it will result in unexpected behavior. In the configuration, you will find the possibility to include or exclude specific models.

Configuration

Use the following command to publish the lada-cache.phpconfig file to your configuration folder:

php artisan vendor:publish

Console commands

You may truncate the cache by running the following command:

php artisan lada-cache:flush

If you want to temporarily disable the cache (for example before running migrations), use these commands:

php artisan lada-cache:disable
php artisan lada-cache:enable

Known issues and limitations

  • Doesn't work with raw SQL queries. This would require an SQL parser to be implemented which is quite hard and very inefficient. As long as you are only using raw queries for reading data, it just won't get cached. Serious issues will only occur if you use raw queries for writing data (which you shouldn't be doing anyway).
  • Doesn't work with multiple connections if done like DB::connection('foo'). Instead, specify the protected $connection = 'foo'; property in the relevant models.
  • The cache must be truncated manually after migrations are executed.
  • Pessimistic locking (sharedLock, lockForUpdate) requires usage of raw SQL queries.
  • Some third-party packages are not working well together with Lada Cache. A workaround for most of the issues can be found here.

Contributing

Contributions in any form are welcome. Please consider the following guidelines before submitting pull requests:

  • Coding standard - It's PSR-2
  • Add tests! - Your PR won't be accepted if it doesn't have tests.
  • Create feature branches - I won't pull from your master branch.

License

Lada Cache is free software distributed under the terms of the MIT license.

spiritix photo

Consulting CTO | Startup Advisor


Spiritix Lada Cache Related Articles

Jeffrey Way's PhpStorm Setup in 2024 image

Jeffrey Way's PhpStorm Setup in 2024

Read article
Laravel Holiday Giveaway image

Laravel Holiday Giveaway

Read article
Laravel Schemaless Attributes Package image

Laravel Schemaless Attributes Package

Read article
Five Minutes with PHP Bard image

Five Minutes with PHP Bard

Read article
The Artisan Files: Mathias Hansen image

The Artisan Files: Mathias Hansen

Read article
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit: Laravel SaaS Starter Kit

SaaSykit is a Multi-tenant Laravel SaaS Starter Kit that comes with all features required to run a modern SaaS. Payments, Beautiful Checkout, Admin Panel, User dashboard, Auth, Ready Components, Stats, Blog, Docs and more.

SaaSykit: Laravel SaaS Starter Kit
Acquaint Softtech logo

Acquaint Softtech

Acquaint Softtech offers AI-ready Laravel developers who onboard in 48 hours at $3000/Month with no lengthy sales process and a 100 percent money-back guarantee.

Acquaint Softtech
Lucky Media logo

Lucky Media

Get Lucky Now - the ideal choice for Laravel Development, with over a decade of experience!

Lucky Media
Shift logo

Shift

Running an old Laravel version? Instant, automated Laravel upgrades and code modernization to keep your applications fresh.

Shift
Tinkerwell logo

Tinkerwell

The must-have code runner for Laravel developers. Tinker with AI, autocompletion and instant feedback on local and production environments.

Tinkerwell