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 删除某个值
优点:无需处理并发问题,降低系统复杂度
缺点:不适合缓存大尺寸对象。会造成阻塞