承接 rouxcool/laravel-redis-advanced-cache 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

rouxcool/laravel-redis-advanced-cache

最新稳定版本:1.2.11

Composer 安装命令:

composer require rouxcool/laravel-redis-advanced-cache

包简介

Advanced Redis-based caching system for Laravel REST and Orion controllers.

README 文档

README

A Redis-based caching system for Laravel, designed to automatically cache API responses, manage query invalidation, and prevent cache collisions between environments.

Author : JORDAN Charly

🚀 Features

  • 🔹 Global Redis Cache Enabled: the advanced cache system is enabled by default (REDIS_ENABLED=true) and automatically intercepts API requests.
  • 🔹 Debug Mode Support: detailed debugging can be toggled via REDIS_ADVANCED_CACHE_DEBUG=true.
  • 🔹 Custom Redis Connection: fully configurable host, port, password, database index, and scheme through environment variables.
  • 🔹 Unique & Isolated Cache Keys: each key is generated using the prefix (MyApp_local_), app name, UUID, request path, HTTP method, user ID, body, and query parameters — ensuring no collisions between environments.
  • 🔹 Smart Route Handling:
    • ✅ Whitelist → all routes (*) are eligible for caching.
    • 🚫 Blacklist → specific routes like api/auth/login are never cached.
  • 🔹 Automatic Cache Invalidation: database write operations (INSERT, UPDATE, DELETE) automatically clear related cache entries.
  • 🔹 Fine-Grained SQL Join Control: when a JOIN query is detected, cache for the right-hand table is flushed automatically (flush.right_table=true).
  • 🔹 Multi-API Compatibility:
    • Orion → ✅ enabled
    • REST → ✅ enabled
    • Other APIs → ❌ disabled
  • 🔹 Authenticated Requests Only: only authenticated users’ requests are cached (cache_authenticated_only=true).
  • 🔹 Custom Cache Lifetime: default TTL is set to 24 hours (86400 seconds).
  • 🔹 Performance-Tuned Flushing: cache invalidation uses Redis SCAN in batches of 300 keys, balancing speed and memory efficiency.
  • 🔹 Automatic Model Resolution: By default, the resolver automatically infers the correct Eloquent model — and therefore the main table name — based on the controller name handling the request.
  • 🔹 Header cache settings:

📦 Installation

Install the package via Composer :

composer require rouxcool/laravel-redis-advanced-cache

publish configuration :

php artisan vendor:publish --tag=config --provider="RedisAdvancedCache\Providers\RedisCacheServiceProvider"

Link in api.php file

use RedisAdvancedCache\Middleware\RedisCacheManager;

Route::middleware(RedisCacheManager::class)->group(function () {
    <!-- Routes -->
});

or app/Http/Kernel.php file

'api' => [
    // ...
    \RedisAdvancedCache\Middleware\RedisCacheManager::class,
],

🧹 Cache Control — Disable & Flush

The Redis Advanced Cache system can be fully disabled or manually refreshed and flushed — directly from API queries, configuration, or Artisan commands.

🔻 Disable Caching via URL or Request Body

You can bypass caching on specific routes by sending a noCache parameter in the URL or request body.

  • 🔹 Disable cache for a request (QUERY parameter):
https://website.com/api/users?noCache=1
  • 🔹 Disable cache for a request (JSON input):
{
    "cache": {
        "noCache": true
    }
}

♻️ Force Cache Refresh for Specific Keys

You can force Redis to refresh specific cache entries using the updateCache parameter. This is useful when you want to invalidate a subset of cached routes without flushing everything.

  • 🔹 Flush cache keys (JSON parameter):
https://website.com/api/users?updateCache=users,posts,services
  • 🔹 Flush cache keys (JSON input):
{
    "cache": {
        "updateCache": [
            "users",
            "posts",
            "articles"
        ]
    }
}

🧠 SDK Response When a Key Is Cached

When the SDK performs a request and the response is stored in cache, it returns a JSON object containing both the request data and cache metadata.

{
  "data": [
    // ...
  ],
  "cache": {
    "pattern": "@PREFIX:@UUID:@NAME:$PATH:$METHOD:$USER_ID:$BODY_INPUT:$QUERY_INPUT",
    "date_stored": "2025-01-01 00:00:00",
    "key": {
        "cache": "MyApp_local_:my_app_uuid:my_app_id:users:POST:9d2af22a-749f-4486-99d5-9ff40651c0f4:ad31168f10a1b0eea70fdc893202366e:dd458db91733e6de79974ad7235ccac2",
      "localstorage": "a99784671d053d496f6d6c6956d87189"
    }
  }
}

⚙️ Manual Cache Control

In addition to automatic API caching, the package also allows manual control of Redis cache entries via the RedisCacheService. This is particularly useful when you need to store, invalidate, or flush specific cache keys programmatically.

Available Methods:

🔹 get(?Request $request = null, ?string $key = null): ?array Return array keys from request or custom key.

use RedisAdvancedCache\Services\RedisCacheService;

$cache = app(RedisCacheService::class);

$resultsKeys = $cache->get($request);
$resultsKeys = $cache->get(null, 'users');

🔹 set(string $key, mixed $value, ?int $ttl = null): bool Store a custom value in Redis with an optional TTL (time-to-live).

use RedisAdvancedCache\Services\RedisCacheService;

$cache = app(RedisCacheService::class);

$cache->set('custom:user:data', ['id' => 12, 'name' => 'John'], 3600);
$cache->set('custom:token', 'abc123');

🔹 delete(string $key): bool Manually remove a specific cache entry.

use RedisAdvancedCache\Services\RedisCacheService;

$cache = app(RedisCacheService::class);
$cache->delete('custom:user:data');

🔹 flushAll(bool $onlyPrefixed = true): void Completely clear cached data. By default, this only deletes keys starting with your app prefix (for example: MyApp_local_).

use RedisAdvancedCache\Services\RedisCacheService;

$cache = app(RedisCacheService::class);
$cache->flushAll(true);
$cache->flushAll(false);

🧩 Configuration

The configuration file allows you to control all aspects of caching. Example config/redis-advanced-cache.php:

General configuration:

'enabled' => env('REDIS_ENABLED', true),
'debug' => env('REDIS_ADVANCED_CACHE_DEBUG', false),

Establish a connection:

'connection' => [
    'host' => env('REDIS_HOST', '127.0.0.1'),
    'port' => env('REDIS_PORT', 6379),
    'password' => env('REDIS_PASSWORD', null),
    'database' => env('REDIS_DB', 1),
    'scheme' => env('REDIS_ADVANCED_CACHE_SCHEME', 'tcp'),
],

Edit pattern cache: Default pattern is @PREFIX:@UUID:@NAME:$PATH:$METHOD:$USER_ID:$BODY_INPUT:$QUERY_INPUT

'pattern' => env('REDIS_ADVANCED_CACHE_PATTERN', 'default'),

Edit static key identifier:

'key_identifier' => [
    'prefix' => env('REDIS_PREFIX', 'MyApp_local_'),
    'name' => env('APP_NAME', 'myapp'),
    'uuid' => env('APP_UUID', 'uuid'),
],

Routes whitelists/blacklists:

'whitelists' => [
    'enabled' => env('REDIS_ADVANCED_CACHE_WHITELIST', false),
    'routes' => [
        '*',
    ],
],

'blacklists' => [
    'enabled' => env('REDIS_ADVANCED_CACHE_BLACKLIST', true),
    'routes' => [
        'api/auth/login',
    ],
],

Listen to database write queries for automatic cache invalidation:

'listen_queries' => env('REDIS_ADVANCED_CACHE_LISTEN_QUERIES', true),

Controller to Model Mapping

'controller_model_mapping' => [
    'Namespace\Controllers' => 'Namespace\Models'
],

API-specific cache toggles

'apis' => [
    'orion'  => env('REDIS_ADVANCED_CACHE_API_ORION', true),
    'rest'   => env('REDIS_ADVANCED_CACHE_API_REST', true),
    'others' => env('REDIS_ADVANCED_CACHE_API_OTHERS', false),
],

Flush queries toggles

'flush' => [
    'right_table' => env('REDIS_ADVANCED_CACHE_FLUSH_RIGHT_TABLE', true),
    'left_table' => env('REDIS_ADVANCED_CACHE_FLUSH_LEFT_TABLE', false),
    'on_left' => env('REDIS_ADVANCED_CACHE_FLUSH_ON_LEFT', false),
    'on_right' => env('REDIS_ADVANCED_CACHE_FLUSH_ON_RIGHT', false),
],

Advanced cache options:

'options' => [
    'cache_authenticated_only' => env('REDIS_ADVANCED_CACHE_AUTH_ONLY', true),
    'cache_flush_scan_count'   => env('REDIS_ADVANCED_CACHE_FLUSH_SCAN_COUNT', 300),
    'ttl'                      => env('REDIS_ADVANCED_CACHE_TTL', 86400),
],

统计信息

  • 总下载量: 523
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-10-08