laravel 基础教程 —— Redis

配置

Redis 在选择中的配置文件存储在
config/database.php。在这一个文件中,你可以看来一个饱含了 Redis
服务新闻的 redis 数组:

'redis' => [
  'cluster' => false,

  'default' => [
    'host' => '127.0.0.1',
    'port' => 6379,
    'database' => 0,
  ],
],

对此开发以来,默许的安插已经完全可以满意大多数的使用了。但是,你可以肆意的在您条件中修改那么些布局。你可以概括的丰裕Redis 服务的称号,并且指定相应的服务器地址和端口。

cluster 选项会告诉 Laravel Redis 客户端在您的 Redis
集群中开展客户端的分片,这样就可以结合节点池并且创立大气有效的
RAM。然而,你须求注意的是客户端分片并无法处理故障转移。由此,它最主要用以从一个尊敬数据存储地方获取可用的缓存数据。

其它,你可以在您的 Redis 连接定义里添加一个 options
数组,这样您能够指定 Predis 的
客户端选项

假设您的 Redis 服务器引入了证实机制,那么你需求在您的 Redis
服务配置数组中添加一个 password 配置项来提供密码。

只顾:假使你通过 PECL 来安装的 Redis PHP 伸张,那么您需求在
config/app.php 文件中对 Redis 的别名举办重命名。

发布、订阅

Laravel 也对 Redis 的 publishsubscribe
命令提供了一种有益的接口。这几个 Redis
命令允许你通过给定的频段来监听音信。你能够从别的使用中向频道中公布音信,更甚者你可以采取任何的言语来展开揭穿,你可以轻易的在行使
/ 进度间举办广播发布:

<?php

namespace App\Console\Commands;

use Redis;
use Illuminate\Console\Command;

class RedisSubscribe extends Command
{
  /**
   * The name and signature of the console command.
   *
   * @var string
   */
   protected $signature = 'redis:subscribe';

   /**
    * The console command description.
    *
    * @var string
    */
    protected $description = 'Subscribe to a Redis channel';

    /**
     * Execute the console command.
     *
     * @return mixed
     */
     public function handle()
     {
       Redis::subscribe(['text-channel'], function ($message) {
         echo $message;
       });
     }
}

当今,你可以使用 publish 方法来向频道中发表音信:

Route::get('publish', function () {
  // Route logic...

  Redis::publish('test-channel', json_encode(['foo' => 'bar']));
})

订阅通配符

你可以运用 psubscribe
方法来订阅统配符匹配的频段,那平日用来捕获频道中的所有音讯。$channel
变量会活动的传递到 Closure 的第三个参数:

Redis::psubscribe(['*'], function ($message, $channel) {
  echo $message; 
});

Redis::psubscribe(['users.*'], function ($message, $channel) {
  echo $message; 
});

Redis

简介

Redis
是一个开源高效的键值对存储系统。它一般用作为一个数据结构服务器来囤积键值对,它可以支撑字符串,散列,列表,集合,和平稳聚集。在
laravel 中利用 Redis 从前,你需求经过 Composer 来设置 predis/predis
包(~1.0)。

基本功能法

你可以由此选用 Redis 假面的种种法子来与 Redis 举办交互。Redis
假面帮助动态方法,这意味着你可以在 Redis 假面上调用任何的 Redis
命令,假面会间接将指令传递给
Redis。比如,我们通过 Redis 假面的 get 方法来调用 GET 命令:

<?php

namespace App\Http\Controllers;

use Redis;
use App\Http\Controllers\Controler;

class UserController extends Controller
{
  /**
   * Show the profile for the given user.
   *
   * @param int $id
   * @return Response
   */
   public function showProfile($id)
   {
     $user = Redis::get('user:profile:'. $id);

     return view('user.profile', ['user' => $user]);
   }
}

理所当然,就像是我们前面所涉嫌的,你可以经过 Redis 假面调用任何的 Redis
命令。Laravel 使用魔术点子来将其传递到 Redis
服务器,所以,能够平素省略的传递命令所需的参数即可:

Redis::set('name', 'Taylor');

$value = Redis::lrange('names', 5, 10);

除此以外,你也足以通过 command
方法来将指令传递到服务器,它接受第二个参数作为命令名称,首个参数数组作为传递命令的参数值:

$values = Redis::command('lrange', ['name', 5, 10]);

使用多 Redis 连接

您可以由此选拔 Redis::connection 方法来收获 Redis 的实例:

$redis = Redis::connection();

那会回到默许的 Redis
服务器的实例。假诺你从未应用集群服务,你可以传递配置文件中所定义的服务名称到
connection 方法中:

$redis = Redis::connection('other');

流程命令

管道流水线可以允许你在一个操作中对 Redis 服务器执行七个指令。pipeline
方法接收一个参数: Closure ,它会吸纳 Redis
的实例。你可以在闭包中公布所有的下令,它们将会在一个操作中进行处理:

Redis::pipeline(function ($pipe) {
  for ($i = 0; $i < 1000; $i++) {
    $pipe->set("key:$i", $i);
  } 
});

相关文章