Redis是什么
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set –有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。
Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。
redis的官网地址,非常好记,是redis.io。(特意查了一下,域名后缀io属于国家域名,是british Indian Ocean territory,即英属印度洋领地)
以上内容来自百度百科
Laravel中如何去安装Redis
Composer安装
composer require predis/predis
配置Config文件
应用的Redis配置位于配置文件 config/database.php
这个文件中包含被应用使用的Redis服务器的Redis数组1
2
3
4
5
6
7
8
9
10
11
12'redis' => [
'client' => 'predis',
'default' => [
'host' => env('REDIS_HOST', '127.0.0.1'),
'password' => env('REDIS_PASSWORD', null),
'port' => env('REDIS_PORT', 6379),
'database' => 0,
],
],
如若是在本地环境中搭建的Redis服务器
默认不需要进行变更可以直接使用
Laravel中Redis常用的指令
获取所有键
Redis::command('keys',['*']);
获取指定键值
Redis::get(key_name)
设置键值
Redis::set(key_name,value)
设置键值并且设定过期时间(单位:s)
Redis::setex(key_name,timeout,value)
删除键值
Redis::del(key_name)
add操作,不会覆盖已有值
Redis::setnx(key_name,value)
添加成功则返回True
如果已经存在该键值则返回False
自增自减 常用来计数
Redis::incr(key_name)
自增1Reids::incrby(key_name,foot)
自增foot
是否存在
Redis::exists(key_name)
设置key的时效性(单位:s)
Redis::expire(key_name,timeout)
获取剩余有效期(单位:s)
Redis::ttl(key_name)
重新设定为永久存储
Redis::persisit(key_name)
总结
其实在Laravel中
Redis的实现命令与在原生PHP中的实现命令并无差异
但是在使用过程中的确更为方便