laravel 操做 redis

laravel框架中自己已经存在相应的redis的配置咱们在使用的时候只须要更改配置便可,可是在使用的时候必定要注意命名空间的问题,具体可查看config/app.php下面的aliases数组中具体的路径php

一、安装启动Redis及依赖包

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

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

composer require predis/predis 1.0.*

二、配置Redis

前面咱们已经提到Redis能够用做主数据库,因此Laravel中Redis的配置信息位于 config/database.php 中:redis

'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

链接时选择的数据库索引ruby

没有设置索引
timeout 链接到Redis服务器超时时间 5秒
read_write_timeout 经过网络链接进行读写操做的超时时间

系统默认(不限制超时时间的话设置为-1)服务器

另外Redis若是是做为缓存工具,还须要在 config/cache.php 配置 redis 选项:网络

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

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

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

三、基本使用

因为Laravel默认已经将Redis门面添加到 config/app.php 的 aliases 数组中,因此在代码中能够直接使用该门面进行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); } 

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

注:https://www.cnblogs.com/mzli/p/5748608.html

相关文章
相关标签/搜索