Redis是Remote Dictionary Server(远程数据服务)的缩写
由意大利人 antirez(Salvatore Sanfilippo) 开发的一款 内存高速缓存数据库
该软件使用C语言编写,它的数据模型为 key-value
它支持丰富的数据结构,比如 String list hash set sorted set。
可持久化,保证了数据安全。
缓存:
有两种类型 数据缓存、页面缓存(smarty)
使用缓存减轻数据库的负载。
在开发网站的时候如果有一些数据在短时间之内不会发生变化,而它们还要被频繁访问,为了提高用户的请求速度/降低网站的负载,就把这些数据放到一个读取速度更快的介质上,该行为就称作对该数据的缓存动作。
该介质可以是文件、数据库、内存,内存经常用于数据缓存。
页面缓存经常用在CMS内存管理系统里边
数据缓存经常会用在页面的具体数据里边
string是redis最基本的类型
redis的string可以包含任何数据。包括jpg图片或者序列化的对象。
单个value值最大上限是1G字节。
如果只用string类型,redis就可以被看作加上持久化特性的memcache
incr(increament)对陌生或已有key(key的值必须为整型)进行累加1操作
实现网站计数器功能。
操作陌生变量:生成该key变量并取值为1,
操作已有的key变量:要求key的值必须为整型的
list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。
这使得list既可以用作栈,也可以用作队列。
该list链表类型应用场合:
获得最新的10个商品:select * from goods order by id desc limit 10;
获得最新的10个登录用户信息: select * from user order by logintime desc limit 10;
以上两个sql语句可以实现需求,但是数据多的时候,全部数据都要受到影响,对数据库的负载比较高。
如果通过list链表实现以上功能,就会极大节省各方面资源消耗,可以在list链表中保留最新的10个数据,旧的数据从链表中给去除。每次从链表中直接获取数据即可。
list案例:
获得最新的前5个商品信息newgoods。
(新)nokia htc heimei apple samsung xiaomi lenovo huawei(旧)
redis的set是string类型的无序集合。
set元素最大可以包含(2的32次方-1)个元素。
关于set集合类型除了基本的添加删除操作,其他有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐功能。
该类型应用场合:qq好友推荐、微博系统的关注关系使用
微博系统关注关系:
①我去关注他人
②我被别人关注
③大家互相关注
tom关注别人(mary jack xiaoming wang5 wang6)
linken关注别人(yuehan daxiong luce wang5 wang6)
上图有两个set集合类型的数据(tom和linken的好友信息)
tom和linken有各自的好友,也有共同的两个好友,但是他们彼此不是好友
和set一样sorted set也是string类型元素的集合,
不同的是每个元素都会关联一个权。
通过权值可以有序的获取集合中的元素
set类型:集合类型、内部元素没有顺序,同一个集合没有重复元素
list链表类型:内部元素有彼此的先后顺序,同一个链表允许有重复元素
Sort set类型:排序集合类型,相比set类型有排序功能
该Sort set类型适合场合:
获得热门帖子(回复量)信息:select * from message order by backnum desc limit 5;
根据学生成绩排序获得信息等: select * from student order by 成绩 desc limit 100;
(以上需求可以通过简单sql语句实现,但是sql语句比较耗费mysql数据库资源,不如使用redis的sort set更加科学)
案例:利用sort set实现获取成绩高的前5个学生信息(500万个学生)
6. hash数据类型
hash数据类型是redis模仿数据库把一条记录信息给存储起来