laravel使用Redis实现网站缓存读取的方法详解
redis的简介
redis 是完全开源免费的,遵守bsd协议,是一个高性能的key-value数据库。 redis 与其他 key - value
缓存产品有以下三个特点: redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
redis支持数据的备份,即master-slave模式的数据备份。
redis 优势
- 性能极高 – redis能读的速度是110000次/s,写的速度是81000次/s 。
- 丰富的数据类型 – redis支持二进制案例的 strings, lists, hashes, sets 及 ordered sets 数据类型操作。
- 原子 – redis的所有操作都是原子性的,同时redis还支持对几个操作全并后的原子性执行。
- 丰富的特性 – redis还支持 publish/subscribe, 通知, key 过期等等特性。
如何安装redis
1.ubuntu(因为我用的是homestead环境虚拟机是ubuntu的所以只用过这一种方法安装,windows请到 或者 ... )
官方给的ubuntu安装方法
$sudo apt-get update $sudo apt-get install redis-server
由于我的网站采用的laravel的框架,要使用composer的方法安装
composer require predis/predis
如果安装了lumen微框架还需要安装illuminate/redis (5.2.*)
composer require illuminate/redis (5.2.*)
配置
如果安装了lumen
//需要在bootstrap/app.php里面加入此段代码 $app->register(illuminate\redis\redisserviceprovider::class); $app->configure('database');
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) |
read_write_timeout |通过网络连接进行读写操作的超时时间 |系统默认(不限制超时时间的话设置为-1)
另外redis如果是作为缓存工具,还需要在config/cache.php配置redis选项:
'redis' => [ 'driver' => 'redis', 'connection' => 'default', ],
这里的connection对应config/database中redis的默认主机default配置。
完成上述配置之后我们就可以在应用代码中使用redis进行数据存取了。
看一个实例————laravel的mysql与redis搭配
我的想法是在读取的时候会先去缓存中去查找,如果找到那就大吉大利了,找不到再去数据库中查找并且调到缓存中。
if (cache::has($key)){ //首先查寻cache如果找到 $values = cache::get($>key); //直接读取cache return $values; }else{ //如果cache里面没有 $values = db::select($sql); cache::put($key,$value,$time); return $values; }
但是laravel的cache还提供了个remember函数
$values = cache::remember($key,$time,function () { return db::select($this->sql); });
如果缓存有直接读取并返回,如果缓存项在缓存中不存在,则返回给 remember 方法的闭包将会被运行,而且闭包的运行结果将会被存放在缓存中。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
上一篇: PHP读写文件高并发处理操作实例详解