Redis 简介

什么是Redis ?

redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括

  • string(字符串)
  • list(链表)
  • set(集合)
  • zset(sorted set --有序集合)
  • hash(哈希类型)

Redis 是一个居于内存的高性能的key-value数据库,因此它的读写性能都非常的高,也正因为如此,现在几千99%的公司都在使用 redis; 当然除了性能高之外,redis 的的客户端支持也是非常到位:

  • Java
  • C/C++,
  • C#
  • PHP
  • JavaScript
  • Perl
  • Object-C
  • Python
  • Ruby
  • Erlang

因此在实际应用中,它极大方便了开发者,也因此成为众多公司的首选,著名的 spring 框架,也在 spring 框架里集成了 redis, 更是把 redis 推向了顶峰!

各个数据类型的应用场景

类型 简介 特性 场景
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、带权重的消息队列