队列与缓存同时使用redis 怎样可以使用不同的db

1. 在队列中获取缓存,必须把队列的 db 与缓存 db 一致,#

在队列中获取 redis 缓存,缓存的 db 会切换为队列的 Db ,会导致辞队列中用获取不到,或者用 remember 删除后不会获取到最新,都是首次的,问题就是因在队列中获缓存走队列的 redis 对应的 db 了,目前解决只能队列与缓存使用同样的 db , 这个是 bug 还是设计问题,有没有解决方法了。

1). 当前使用的 Laravel 版本?#

laravel10

2). 当前使用的 php/php-fpm 版本?#

PHP 版本:

php8.2

3). 非驱动与 redis 配置问题#

问题原因,如缓存使用了 db1 队列用 bd2 如下配置:
REDIS_CLIENT=predis
REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379
REDIS_DEFAULT_DB=0

#缓存走的 redis 库 1
REDIS_CACHE_DB=1

#队列走的 redis 库 2
REDIS_QUEUE_DB=2
REDIS_SESSION_DB=3

这种情况下,在队列中获取缓存,缓存会自动切换为队列库 2 中,因为队列提前使用了队列的 db2,在里面继续使用 cache 会以队列的 db 获取,正常 Cache 应获取 db1 才正确,仅队列影响,其它如命令行、fpm 下运行相关是没有问题的,或者把缓存与队列的 db 都设相同就没有问题了,或者队列与缓存用各自的 driver 也不会有问题,问题是使用相同的 driver 相同的 redis 库用不同有 db 表仅在队列下获取缓存才会有这个问题,

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 4

和 DB 一样都可以指定 connection 的

1年前 评论

指定 connection 就可以了:

\Illuminate\Support\Facades\Redis::connection('default');

config/database.php 里面可以看到 Redis 的配置:

'default' => [
    'url'      => env('REDIS_URL'),
    'host'     => env('REDIS_HOST', '127.0.0.1'),
    'password' => env('REDIS_PASSWORD', null),
    'port'     => env('REDIS_PORT', 6379),
    'database' => env('REDIS_DB', 0), // 设置该 connection 的 db
],
1年前 评论

配置文件 cache.php

'redis' => [
    'driver' => 'redis',
    'connection' => 'cache',
    'lock_connection' => 'default',
],

数据库文件 database.php

'cache' => [
    'url' => env('REDIS_URL'),
    'host' => env('REDIS_HOST', '127.0.0.1'),
    'username' => env('REDIS_USERNAME'),
    'password' => env('REDIS_PASSWORD'),
    'port' => env('REDIS_PORT', '6379'),
    'database' => env('REDIS_CACHE_DB', '1'),
],

结论,多配置几个 database 驱动,在 cache.php 配置想赢的驱动

1年前 评论

env 配置一下就好

# redis库
REDIS_DATABASE=
# redis缓存库
REDIS_CACHE_DB=
1年前 评论