laravel配置Redis多个库的实现方法

时间:2021-05-26

导语

经过编译安装和安装扩展之后,Redis 已经可以正常使用了。但是在 laravel 中还需要其他的操作。

安装扩展

要想在 laravel 中使用 Redis,还需要安装 predis 扩展。使用 composer require predis/predis 进行安装就可以了。

修改配置

  • Redis 的配置在 config/database.php 文件,根据需求修改,我这里不需要改动;
  • 设置 Cache 默认缓存为 Redis,在 .evn 文件中 CACHE_DRIVER=redis;
  • 设置 Session 的驱动为 Redis,在 .env 文件中 SESSION_DRIVER=redis;
  • 配置多个库

    经过以上的配置后,多个服务都使用 Redis,如果都使用同一个库,这显然是不合理的。我们可以配置多个连接来解决这个问题。
    Redis 默认有 16 个库,在服务器中设置 redis.conf 的 database 值可以修改。

    先来看下 config/database.php 的默认连接

    'redis' => [ 'client' => 'predis', 'default' => [ 'host' => env('REDIS_HOST', '127.0.0.1'), 'password' => env('REDIS_PASSWORD', null), 'port' => env('REDIS_PORT', 6379), 'database' => env('REDIS_DB', 0), ], 'cache' => [ 'host' => env('REDIS_HOST', '127.0.0.1'), 'password' => env('REDIS_PASSWORD', null), 'port' => env('REDIS_PORT', 6379), 'database' => env('REDIS_CACHE_DB', 1), ], ],

    默认是有两个连接的,分别是 default 和 cache。下面来看下 config/cache.php 中关于 Redis 的配置

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

    可以看到它的 connection 值是 cache,也就是使用 config/database.php 中 Redis 的 cache。

    下面修改 config/database.php 的 Redis,添加一个 session 的连接,如下

    'redis' => [ 'client' => 'predis', 'default' => [ 'host' => env('REDIS_HOST', '127.0.0.1'), 'password' => env('REDIS_PASSWORD', null), 'port' => env('REDIS_PORT', 6379), 'database' => env('REDIS_DB', 0), ], 'cache' => [ 'host' => env('REDIS_HOST', '127.0.0.1'), 'password' => env('REDIS_PASSWORD', null), 'port' => env('REDIS_PORT', 6379), 'database' => env('REDIS_CACHE_DB', 1), ], 'session' => [ 'host' => env('REDIS_HOST', '127.0.0.1'), 'password' => env('REDIS_PASSWORD', null), 'port' => env('REDIS_PORT', 6379), 'database' => env('REDIS_SESSION_DB', 2), ], ],

    接下来在 .env 中添加 SESSION_CONNECTION=session。

    测试

    经过上面的操作,已经修改好了。总结下就是 default 使用的是 0 库,cache 使用的是 1 库,session 使用的是 2 库。

    使用如下代码来测试下

    /** * 测试 Redis 的存储 */ public function testRedis() { // Redis 门面 Redis::setex('facades', 30, 'i am facades'); // Cache Cache::put('cache', 'i am cache', now()->addMinute(30)); // 因为 Cache 默认是 Redis,所有和上面语句相同 // Cache::store('redis')->put('cache', now(), now()->addMinute(30)); }

    运行以上代码之后,在服务器中使用 redis-cli 来看下存储情况

    可以看到各个库的存储情况

  • 使用 Redis 门面操作,默认为 config/database.php 中 Redis 的 default 连接,数据存入 0 库;
  • 使用 Cache 操作,因为 config/cache.php 中 Redis 的 connection 设置为 cache,理所当然存入的是 1 库;
  • Session 也根据 SESSION_CONNECTION=session 配置,正确的存入了 2 库;
  • 使用 Redis 门面的时候,也可以指定连接

    $redis = Redis::connection('session');$redis->setex('facades_connection', 30, 'i am facades_connection');

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

    声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章