Part of Jardis — the Domain-Driven Design platform for PHP. You model your domain; Jardis generates the production-ready hexagonal code (DTOs, Command/Query handlers, repositories, persistence). This package is part of the open-source foundation that generated code runs on.
A PSR-16 cache for PHP with multi-layer chaining. Stack Memory, APCu, Redis, and Database backends in a single Cache instance. On a cache miss in a fast layer, the value is automatically backfilled from the next slower layer — so subsequent reads hit the fastest backend available. Writes propagate to all configured layers simultaneously.
- Multi-Layer Chain — Stack any number of backends; reads backfill upper layers automatically
- 5 Backends —
CacheMemory,CacheApcu,CacheRedis,CacheDatabase,CacheNull - PSR-16 — Full
Psr\SimpleCache\CacheInterfaceimplementation on every layer - Namespace Isolation — Each layer instance carries its own namespace prefix
- Immutable After Construction — All layers set via constructor; no mutation at runtime
- Null Object Pattern — Empty
Cache([])degrades gracefully to a no-opCacheNull - TTL Support — Integer seconds or
DateIntervalon everyset()/setMultiple() - Zero Dependencies — No third-party packages required beyond PSR interfaces
composer require jardisadapter/cacheuse JardisAdapter\Cache\Cache;
use JardisAdapter\Cache\Adapter\CacheMemory;
use JardisAdapter\Cache\Adapter\CacheRedis;
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
// Two-layer cache: L1 = in-process memory, L2 = Redis
$cache = new Cache([
new CacheMemory('myapp'),
new CacheRedis($redis, 'myapp'),
]);
$cache->set('user:42', $userData, ttl: 300);
$user = $cache->get('user:42');use JardisAdapter\Cache\Cache;
use JardisAdapter\Cache\Adapter\CacheMemory;
use JardisAdapter\Cache\Adapter\CacheApcu;
use JardisAdapter\Cache\Adapter\CacheRedis;
use JardisAdapter\Cache\Adapter\CacheDatabase;
// Four-layer cascade: L1 memory → L2 APCu → L3 Redis → L4 database
// A miss at L1 checks L2, then L3, then L4.
// When found, the value is written back into all faster layers automatically.
$cache = new Cache([
new CacheMemory('orders'),
new CacheApcu('orders'),
new CacheRedis($redis, 'orders'),
new CacheDatabase($pdo, namespace: 'orders'),
]);
// Bulk operations — all layers updated in one call
$cache->setMultiple([
'order:101' => $order101,
'order:102' => $order102,
], ttl: 600);
$orders = $cache->getMultiple(['order:101', 'order:102']);
// Invalidate a key across all layers
$cache->delete('order:101');
// Expire stale database entries explicitly
$dbLayer = new CacheDatabase($pdo, namespace: 'orders');
$dbLayer->cleanExpired();Full documentation, guides, and API reference:
docs.jardis.io/en/adapter/cache
This package is licensed under the MIT License.
Jardis · Documentation · Headgent
Dieses Package liefert einen Skill für Claude Code, Cursor, Continue und Aider mit. Installation im Konsumentenprojekt:
composer require --dev jardis/dev-skillsMehr Details: https://docs.jardis.io/en/skills