不知道是多久之前,我们系统的只需要从数据库读取出数据,展示在页面就可以了。后来系统越来越复杂了,传统的模式越来越难以支撑,缓存技术也在系统中占据越来越重要的角色。
1、redis的两大优势。
-
高性能
假设下如果所有的数据都从数据库中读取,特别是是一些复杂的数据,每次都查询mysql性能必定非常差。所以对于一些复杂操作耗时查出来的结果且确定后面不怎么变化的数据放到缓存,能大幅提高系统响应。
-
高并发
mysql单机一般只能支撑到2000Qps,而redis由于是K/V式的操作,单机可以支撑并发量几万到十几万。
2、 redis为什么这么快
-
单线程简单、无线程开销
使用单线程简单,避免了多线程的竞争;同时还省去了多线程切换带来的时间和性能上的开销。
redis4.0之前用的是单线程模式,主要的I/O线程和基本操作是单线程的,但是redis的持久化、集群同步还是使用其他线程的。
Redis4.0之后添加了多线程支持,主要体现在大数据的异步删除上
-
redis主要基于内存操作
内存的执行效率本身就很快,并且redis还采用了高效的数据结构。
-
在请求上采用I\O多路复用机制
多路复用机制是一种基于非阻塞I/O模型,可以使redis高效的进行网络通信,I/O的读写也不再阻塞,就可以处理大量的客户端socket请求。
3、 redis支持的数据结构
上面我们说过redis采用了高效的数据结构,Redis支持5种数据类型:string,hash,list,set,zset。
-
String字符串
String是redis最基本的类型,一个key对应一个value。String类型是二进制安全的,可以包含任何数据,比如图片和序列化对象。Value值最大能存储512M数据
赋值:set key1 “张三”;取值:get key1
-
Hash 哈希
hash 是一个键值对的集合,是一个string 类型的field 和value的映射表,特别适合存储对象。
命令: hset key1 field1 value
赋值:hset zhangsan name “张三”;hset zhangsan sex “男”
取值:hget zhangsan name
-
List 有序列表
List列表是简单的字符串列表,按照插入顺序排序,可以添加元素到列表的头部或者尾部。适合做粉丝列表、评论列表之类的。List就是链表,我们可以实现最新消息排行。
场景:粉丝列表,最新消息排行,队列,高效的分页
命令:lpush,lpop,rpush,rpop,lrange
赋值:
1、lpush list1 a
2、lpush list1 b
3、lpush list1 c
取值:lrange list1 0 -1 ,返回 c b a
Lpop list1 移除第一个元素 c
Rpop list1 移除最后一个元素 a
我们还可以用lrange 做一个简单高效的分页,还是可以通过rpop 构建一个消息队列。
-
Set 无序集合
Redis set是string类型的无序集合,集合是通过hashtable实现的,基本功能和list差不多,最大的区别在于去重,Set可以自动去重,可以知道一个元素是否存在,适合的场景好友的共同爱好。
场景:用于交集、并集、差集,自动去重。
-
Zset 有序集合
Redis zset 也是string类型的集合,且不允许有重复。Redis sorted set的使用场景与set类似,区别是set不是自动有序的,而sorted set可以通过用户额外提供一个优先级(score)的参数来为成员排序,并且是插入有序的,即自动排序。
场景:分数排行榜