简介:Redis是完全开源的遵守BSD协议的高性能的k-v数据库。
特点:
- Redis支持数据的持久化,可以将内存中的数据库保存到磁盘中,重启的时候可以再次加载使用
- Redis支持 k-v、list、set、zset、hash等数据结构的存储
- Redis支持数据的备份,即master-slave的数据备份 优势:
- 性能极高 Redis读的速度是110000次/s,写的速度是81000次/s
- 数据类型丰富
- 原子 Redis的所有操作都是原子性的,要么成功执行要么完全不执行,单个操作是原子性的,多个操作也支持事务,即原子性。通过MULTI和EXEC指令包起来。
Redis数据类型
Redis支持五中数据类型:String(字符串),hash(哈希),list(列表),set(集合),zset(sorted set:有序集合)
String(字符串)
String是Redis最基本的类型,一个key对应一个value。String类型是二进制安全的。意思是Redis的string可以包含任何数据,包含图片或序列化对象,最大的能存储512MB。
Hash(哈希)
Redis hash是一个键值对集合。是一个String类型的field和value的映射表,特别适合用于存储对象。
List(列表)
Redis;列表是简单的字符串对象,按照插入顺序排序
Set(集合)
Redis的Set是String类型的无序集合
zset(sorted set:有序集合)
Redis zset和set一样也是string类型元素的集合,且不允许重复的成员。 里面的每个元素都会关联一个double类型的分数。Redis就是通过分数为集合中的成员进行从小到大的排序。 zset的成员是唯一的,但分数(score)却可以重复
| String(字符串) | 二进制安全 | 可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存储512M | 用途 |
|---|---|---|---|
| Hash(字典) | 键值对集合,即编程语言中的Map类型 | 适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值(Memcached中需要取出整个字符串反序列化成对象修改完再序列化存回去) | 存储、读取、修改用户属性 |
| List(列表) | 链表(双向链表) | 增删快,提供了操作某一段元素的API | 1,最新消息排行等功能(比如朋友圈的时间线) 2,消息队列 |
| Set(集合) | 哈希表实现,元素不重复 | 1、添加、删除,查找的复杂度都是O(1) 2、为集合提供了求交集、并集、差集等操作 | 1、共同好友 2、利用唯一性,统计访问网站的所有独立ip 3、好友推荐时,根据tag求交集,大于某个阈值就可以推荐 |
| Sorted Set(有序集合) | 将Set中的元素增加一个权重参数score,元素按score有序排列 | 数据插入集合时,已经进行天然排序 | 1、排行榜 2、带权重的消息队列 |