Laravel 5.1中 Redis 的安装配置及基本使用教程

laravel-redis

关于Redis的介绍我们在之前Laravel 缓存配置一节中已有提及,Redis是一个开源的、基于内存的数据结构存储器,可以被用作数据库、缓存和消息代理。相较Memcached而言,支持更加丰富的数据结构,包括字符串、哈希、列表、集合、有序集合等,此外还支持将数据持久化到数据库。更多关于Redis的介绍可查看其官网介绍。今天我们只是简单讲述在Laravel中如何对Redis依赖包进行安装配置和使用。

1、安装启动Redis及依赖包

如果使用的是Homestead虚拟机作为本地开发环境的话,Homestead已经为我们安装好了Redis并开机启动,如果是使用Windows开发环境的话,可参考这篇文章安装启动Redis。

Redis启动之后,还需要在Laravel项目根目录下运行如下命令使用Composer安装predis依赖包:

composer require predis/predis 1.0.*

2、配置Redis

前面我们已经提到Redis可以用作主数据库,所以Laravel中Redis的配置信息位于config/database.php中:

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

其中cluster选项表示是否在多个Redis节点间进行分片,这里我们本地测试只有一个节点故将其设置为false

default选项表示默认Redis主机连接,这里Redis和Web服务器共用一台主机,所以host为127.0.0.1,Redis默认端口是6379。

此外,default选项还支持更多连接参数(如果需要的话):

参数
意义
默认值
host 服务器IP地址/主机名称 127.0.0.1
port Redis服务器监听的端口号 6379
password 如果服务器需要认证密码 不使用密码
database
连接时选择的数据库索引
没有设置索引
timeout
连接到Redis服务器超时时间 5秒
read_write_timeout 通过网络连接进行读写操作的超时时间
系统默认(不限制超时时间的话设置为-1)

另外Redis如果是作为缓存工具,还需要在config/cache.php配置redis选项:

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

这里的connection对应config/databaseredis的默认主机default配置。

完成上述配置之后我们就可以在应用代码中使用Redis进行数据存取了。

3、基本使用

由于Laravel默认已经将Redis门面添加到config/app.phpaliases数组中,所以在代码中可以直接使用该门面进行Redis操作。我们可以在Redis门面上以静态方法的方式调用Redis客户端提供的任何命令(Redis命令大全),然后Laravel使用魔术方法将命令传递给Redis服务器并返回获取的结果。

下面我们来看最简单的读取操作:

$key = 'user:name:6';

$user = User::find(6);
if($user){
    //将用户名存储到Redis中
    Redis::set($key,$user->name);
}

//判断指定键是否存在
if(Redis::exists($key)){
    //根据键名获取键值
    dd(Redis::get($key));
}

以上是简单的字符串存取,下面我们看一个更复杂的例子,将获取到的数据存放到集合中:

$key = 'posts:title';

$posts = Post::all();
foreach ($posts as $post) {
    //将文章标题存放到集合中
    Redis::sadd($key,$post->title);
}

//获取集合元素总数(如果指定键不存在返回0)
$nums = Redis::scard($key);

if($nums>0){
    //从指定集合中随机获取三个标题
    $post_titles = Redis::srandmember($key,3);
    dd($post_titles);
}

注:集合与列表的区别在于集合中是不允许重复元素出现的,没错,这就是数学中集合的互异性的体现;有序集合与集合的区别在于有序集合是有序的,这则是数学集合无序性的体现。

更多使用方法参考Laravel的Redis文档

学院君 has written 680 articles

资深PHP工程师,Laravel学院院长

20 thoughts on “Laravel 5.1中 Redis 的安装配置及基本使用教程

  1. 毛毛 says:

    ==> homestead-7: Booting VM…There was an error while executing `VBoxManage`, a CLI used by Vagrantfor controlling VirtualBox. The command and stderr is shown below.Command: [“startvm”, “ef87515f-b462-416f-85bf-08ccdb8ca601”, “–type”, “headless”]Stderr: VBoxManage.exe: error: The virtual machine ‘homestead-7’ has terminated unexpectedly during startup with exit code 1 (0x1). More details may be available in ‘D:DaMao文档VirtualBox VMshomestead-7LogsVBoxHardening.log’VBoxManage.exe: error: Details: code E_FAIL (0x80004005), component MachineWrap, interface IMachine学院君 我的是Win10平台运行成功了一次 然后重启了电脑,就一直这样了 ,重装也不行 , 有时解决方案吗.

  2. STay says:

    报了个错,ConnectionException in AbstractConnection.php line 168,说无法连接tcp://127.0.0.1:6379
    原以为端口被占用,去查了一下并没有。我的设置是’default’ => env(‘CACHE_DRIVER’, ‘redis’)和
    ‘redis’ => [
    ‘cluster’ => false,
    ‘default’ => [
    ‘host’ => ‘127.0.0.1’,
    ‘port’ => 6379,
    ‘database’ => 0,
    ],
    ],话说评论支持markdown吗?

          1. 郑方方 says:

            [生病]学院君,我已经百度了,不知道什么原因出现这个问题Non-static method Redis::set() cannot be called statically, assuming $this from incompatible context,我按照你这个教程来安装redis,并且使用了Redis::set(‘name’, ‘Taylor’);也use Redis了,然后运行报错了~~

          2. 郑方方 says:

            [衰]好吧,以为没事了,整了整,还是有问题…我在window下,用了那个redis.dll,应该就出现问题了,这个你在文档中提过改别名,但是我改成了
            ‘Lredis’ => IlluminateSupportFacadesRedis::class,在controller文件中use Lredis不出来..[赶火车]

          3. 郑方方 says:

            [生病]不是不想安装Homestead,实在是之前安装过,有阴影了。群里的告诉我解决办法了,不过跟你贴出来的或者文档的都不是很一样,起码能用了

发表评论

标记为*的字段是必填项(邮箱地址不会被公开)

你可以使用这些HTML 标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>