如何在同一台服务器上创建另一个Redis服务器实例(由Laravel Forge管理)

时间:2017-08-10 18:18:19

标签: laravel laravel-5 redis laravel-forge

Laravel Horizon即将到来,所以我希望将我的队列从beanstalkd切换到Redis,以利用更好的队列监控。

但是,偶尔我必须执行php artisan cache:clear。但如果我这样做,因为我的队列现在在Redis中,它将消除我的所有工作,如GitHub issue中所述。

建议是制作一个单独的Redis实例。以下是我的问题:

  1. 如何在Laravel Forge托管服务器中创建多个Redis服务器实例?
  2. 我应该在配置文件中更改什么,以便会话和缓存指向一个Redis服务器实例,并且我的队列指向不同的Redis服务器实例? (现在知道答案,请参阅编辑中的链接)
  3. php artisan cache:clear现在只会清除我的缓存正在使用的Redis实例中的数据,而我的队列工作者Redis服务器不受影响是否正确?
  4. 修改

    在进一步搜索互联网后,我遇到了this discussion

    1. 所以我认为我真的不需要创建一个单独的Redis服务器实例,只需使用不同的Redis DB编号。它是否正确?
    2. php artisan cache:clear只清除该号码吗?同一实例上的其他DB编号不受影响吗?

1 个答案:

答案 0 :(得分:5)

  

php artisan cache:清除只清除那个DB号码吗?

这是准确的。向Redis发送cache:clear命令sends a FLUSHDB命令,擦除Redis数据库中用于存储缓存数据的数据。

为每个Laravel服务在单个 Redis实例中隔离数据的标准方法是为 config / database.php中的每个服务分配不同的数据库

'redis' => [ 
    'default' => [
        ... 
        'database' => 0, 
    ], 
    'cache' => [ 
        ...
        'database' => 1, 
    ], 
], 

上面的配置指示Laravel使用数据库1存储缓存数据,并使用数据库0进行所有其他Redis操作。然后,当我们想要使用php artisan cache:clearapp('cache')->flush()等清除缓存时,Laravel不会删除存储在Redis中的其他数据。

我们可以通过创建单独的连接来扩展此配置模式,这些连接为每个会话,队列和广播API指定不同的Redis数据库。随着应用程序的增长,这为管理数据提供了更大的灵活性。

当然,对于大型应用程序,我们甚至可能会为每个服务使用不同的Redis服务器来提高可伸缩性,因为我们的应用程序数据超出了单个Redis服务器的限制。