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请到http://www.redis.net.cn/tutor 或者 https://www.jb51.net/article/84071.htm... )
官方给的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 方法的闭包将会被运行,而且闭包的运行结果将会被存放在缓存中。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:- laravel中Redis队列监听中断的分析
- 关于 Laravel Redis 多个进程同时取队列问题详解
- Laravel如何使用Redis共享Session
- laravel使用redis队列实例讲解