赞
踩
一个有8年开发经验的程序员,主要工作内容CURD,正在向高性能、安全、可扩展方向看齐,为了找工作不得不背一些八股文,但是只背不用没有意义,所以要学以致用。
只有一个value,可以用来锁key,也可以用来做缓存,value也可以是一个对象的JSON串。
计数器:INCR article:readcount:{文章id}
GET article:readcount:{文章id}
web集群session共享:
spring session + redis实现session共享
分布式系统全局序列号:INCRBY orderId 1000
1.常用操作
HSET key field value //存储一个哈希表key的键值
HSETNX key field value //存储一个不存在的哈希表key的键值
HMSET key field value [field value …] //在一个哈希表key中存储多个键值对
HGET key field //获取哈希表key对应的field键值
HMGET key field [field …] //批量获取哈希表key中多个field键值
HDEL key field [field …] //删除哈希表key中的field键值
HLEN key //返回哈希表key中field的数量
HGETALL key //返回哈希表key中所有的键值
HINCRBY key field increment //为哈希表key中field键的值加上增量increment
2.使用场景
可以对对象的多字段信息进行缓存。
购物车操作:key为cart-1001,商品id为10086
添加商品 hset cart-1001 10086 1
增加数量 hincrby cart-1001 10086 1
商品总数 hlen cart-1001
删除商品 hdel cart-1001 10086
获取购物车所有商品 hgetall cart-1001
优点:
1)同类数据归类整合储存,方便数据管理
2)相比string操作消耗内存与cpu更小
3)相比string储存更节省空间
缺点:
过期功能不能使用在field上,只能用在key上
Redis集群架构下不适合大规模使用
1.常用操作:
LPUSH key value [value …] //将一个或多个值value插入到key列表的表头(最左边)
RPUSH key value [value …] //将一个或多个值value插入到key列表的表尾(最右边)
LPOP key //移除并返回key列表的头元素
RPOP key //移除并返回key列表的尾元素
LRANGE key start stop //返回列表key中指定区间内的元素,区间以偏移量start和stop指定
BLPOP key [key …] timeout //从key列表表头弹出一个元素,若列表中没有元素,阻塞等待 timeout秒,如果timeout=0,一直阻塞等待
BRPOP key [key …] timeout //从key列表表尾弹出一个元素,若列表中没有元素,阻塞等待 timeout秒,如果timeout=0,一直阻塞等待
2.使用场景:
Stack(栈) = LPUSH + LPOP
Queue(队列)= LPUSH + RPOP
Blocking MQ(阻塞队列)= LPUSH + BRPOP
可以做消息流,比如微博消息
我关注了用户1,key为msg:{我的用户id}
用户1发了一条微博消息:消息ID为10086
LPUSH msg:{我的用户id} 10018
查看最新的消息:
LRANGE msg:{我的用户id} 0 1
1.查用操作:
SADD key member [member …] //往集合key中存入元素,元素存在则忽略,若key不存在则新建
SREM key member [member …] //从集合key中删除元素
SMEMBERS key //获取集合key中所有元素
SCARD key //获取集合key的元素个数
SISMEMBER key member //判断member元素是否存在于集合key中
SRANDMEMBER key [count] //从集合key中选出count个元素,元素不从key中删除
SPOP key [count] //从集合key中选出count个元素,元素从key中删除
SINTER key [key …] //交集运算
SINTERSTORE destination key [key …] //将交集结果存入新集合destination中
SUNION key [key …] //并集运算
SUNIONSTORE destination key [key …] //将并集结果存入新集合destination中
SDIFF key [key …] //差集运算
SDIFFSTORE destination key [key …] //将差集结果存入新集合destination中
2.使用场景:
比如说微信抽奖小程序:
1)点击参与抽奖加入集合
SADD key {userlD}
2)查看参与抽奖所有用户
SMEMBERS key
3)抽取count名中奖者
SRANDMEMBER key [count] / SPOP key [count]
微博点赞收藏:
1)点赞
SADD key:{消息ID} {用户ID}
2) 取消点赞
SREM key:{消息ID} {用户ID}
3) 检查用户是否点过赞
SISMEMBER key:{消息ID} {用户ID}
4) 获取点赞的用户列表
SMEMBERS key:{消息ID}
5) 获取点赞用户数
SCARD key:{消息ID}
微博、微信的关注模型
我关注的人:
mySet-> {用户1, 用户2}
2) 用户1关注的人:
user1Set–> {用户2, 用户3, 用户4}
3) 我和用户1共同关注的人:
SINTER mySet user1Set–> {用户2}
电商系统实现商品的筛选:
1.常用操作:
ZADD key score member [[score member]…] //往有序集合key中加入带分值元素
ZREM key member [member …] //从有序集合key中删除元素
ZSCORE key member //返回有序集合key中元素member的分值
ZINCRBY key increment member //为有序集合key中元素member的分值加上increment
ZCARD key //返回有序集合key中元素个数
ZRANGE key start stop [WITHSCORES] //正序获取有序集合key从start下标到stop下标的元素
ZREVRANGE key start stop [WITHSCORES] //倒序获取有序集合key从start下标到stop下标的元素
ZUNIONSTORE destkey numkeys key [key …] //并集计算
ZINTERSTORE destkey numkeys key [key …] //交集计算
2.使用场景:
新闻排行榜功能:
1)点击新闻
ZINCRBY hotNews:20240301 热点新闻
2)展示当日排行前十
ZREVRANGE hotNews:20240301 0 9 WITHSCORES
3)七日搜索榜单计算
ZUNIONSTORE hotNews:20190224-20240301 7
hotNews:20190224 hotNews:20190225… hotNews:20240301
4)展示七日排行前十
ZREVRANGE hotNews:20190224-20240301 0 9 WITHSCORES
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。