Redis常见的数据类型

  • string字符串

格式: set key value
string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象。
string是redis最基础的数据类型。一个键最大能存储512MB

  • hash哈希

格式:hmset name key1 value1 key2 value2

Redis hash 是一个键值对(key=》value)集合
Redis hash 是一个string类型的filed和value的映射表,hash特别适合用于存储对象。

典型应用场景:用户的购物车信息

hmset user_id_h goodsid_1 num_1 goodsid_2 num_2
  • list列表

格式:lpush name value 在 key 对应 list 的头部添加字符串元素
格式:rpush name value 在 key 对应 list 的尾部添加字符串元素

List是简单的字符串有序列表,按照插入顺序。你可以添加一个元素到列表的头部(left),也可以添加的尾部(right)

  • set集合

成员不允许重复

格式:sadd name value
Redis的set是string类型的无序集合
集合是通过哈希实现的,所以添加,删除,查找的复杂度都是O(1)。

  • zset有序集合

元素有分值,成员不允许重复,分值可以重复

格式:zadd name score value
有序集合不允许重复的成员
不同的每个元素都会关联一个double类型的分数。redis通过分数来为集合成员排序
zset的成员是唯一的,但是分数可以重复


redis 单进程、单线程、阻塞式

memcached 多进程非阻塞式

常用命令:

keys 判断key是否存在  ,谨慎使用key的规模过大容易造成阻塞,推荐使用scan
expires 设置key的过期时间
ttl 读取key的剩余时间
incr 原子递增
decr 原子递减
incrby 可以设置递增的步长
decrby 可以设置递减的步长

//分布式锁常用
setnx key不存在可以设置成功,否则失败
setget 设置新值的同时返回旧值
del 删除某个值

优点:无需处理并发问题,降低系统复杂度
缺点:不适合缓存大尺寸对象。会造成阻塞