15人参与 • 2026-04-30 • Redis
set集合中的每一个元素都是string类型。
set和list非常相似,但是set是无序且不可重复,而list则是有序可重复的。
set集合的底层是value为null的hash表。正是如此,才保证了无序性和不可重复性。
格式:sadd key member 【member...】
说明:如果key不存在,就创建一个只包含member元素作成员的集合。
格式:sismember key member
说明:如果是集合的成员返回1,不过不是,或者key不存在,就返回0
格式:smove source destination member
说明:如果source 集合不存在,或者不包含指定的member元素,则不执行任何操作,返回0
否则会从source中删除member,并添加到destination,返回1。
如果destination已经包含了member,那只是简单的从source中删除member。
格式:srandomember key count
注意:如果count的数量大于集合中元素的个数,就返回整个集合。
如果count为正数,且小于集合长度,那么返回一个包含count个元素的数组,数组中的元素不重复。
如果count为负数,那么返回一个包含count绝对值个元素的数组,数组中的元素可能会重复。
格式:sdiff key1 key2 (取集合key1和key2的差集)
格式:sdiffstore keyres key1 key2 (取集合key1和key2的差集,并保存到keyres)
在服务器中设置用于控制访问的黑名单。
将黑名单写入redis,只要客户端来访问,先在redis中的黑名单查看客户端ip是否存在,存在就拒绝访问,否则访问通过。
有限随机数是指返回的随机数是基于某一集合范围内的随机数,例如抽奖、随机选人等。
通过spop或srandomember 实现从指定集合中随机选出元素。
用户画像就是为每个用户自定义多个反应该用户特征的白哦去,这些标签可以使用sadd添加该用户对应的集合中。这些标签具有无序、不重复特征。
还可以使用sinter/sinterstore 根据用户画像的交集进行好友推荐、商品推荐、客户推荐等。
有序set中的每个元素都是string类型。
有序set和set的不同之处在于,有序set中的每个元素都有一个分值score,redis会根据score的值对集合进行由小到大排序。
有序set的元素不重复,但元素的score可以重复。
由于该类型的命令都是z开头,所以也称作zset。
格式:zadd key score member [score member ...]
注意:score可以是整数或双精度浮点数。
如果集合key不存在,就创建一个空的zset,并执行zadd操作。
如果写入的member值存在,但score不同,新的score会覆盖旧的score。
格式:zrange key start stop [withscores] 或zrevrangekey start stop [withscores]
说明:zrange命令会按score值递增排序。
zrevrange命令会按score值递减排序。
具有相同score值得成员按字典序/逆字典序排序。
可以通过使用withscores 选项,来让成员和它的score值一并返回。
当start大于zset的最大下标,或者start>stop时(两者同为正数或负数时),zrange命令会返回一个空列表。
当stop大于zset的最大下标,那么redis将stop当作最大下标处理。
如果集合中包含大量元素,该命令会阻塞redis服务,所以生产环境一般不使用该命令,而使用zscan代替。
格式:zrangebyscore key min max [withscores] [limit offset count]
zrevrangebyscore key min max [withscores] [limit offset count]
说明:zset按score递增/递减排序。
相同score按字典序/逆字典序排列。
limit参数指定返回结果的数量及区间。
offset 表示从结果的某个下标开始
count表示截取元素的个数。
当offset很大时,定位offset的操作可能需要遍历整个有序集,此过程效率可能会较低。
min和max的取值是正负无穷大。区间的取值用闭区间,也可以给参数前加左括号“(”来使用开区间。
注意:如果使用zrevrangebyscore ,那么start必须大于stop。
# 按score 截取大于20 小于等于60,再从其结果的下标3开始截取7个元素并返回。 zrangebyscore city (20 60 withscores limit 3 7
格式:zcount key min max
格式:zscore key member
格式:zincrby key increment member
格式:zrank key member // 正序名次
zrevrankkey member // 倒序名次
格式:zrem key member [member...]
格式:zremrangebyrank key start stop
格式:zremrangebyscore key min max
格式:zrangebylex key min max [limit offset count]
# 按字典序排序(因为score全部一样),返回区间在[b,e)之间的成员。 zrangebylex ch [b (e
格式:zlexcount key min max
格式:zremrangebylex key min max
各种排行榜。例如音乐、视频平台的排行榜。将播放量作为score,进行排序。
redis安装完毕后会自动安装一个redis-benchmark测试工具,它是一个压力测试工具,用于测试redis性能。
通过redis-benchmark -help 查看其用法。
redis-benchmark -c <clients> # 并行连接的客户端数量,默认50 redis-benchmark -n <requests> # 接收请求总数,默认100000 # 案例:测试并发100个,2万请求 redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 20000 # 案例:测试并发100个,2万请求,指定测试命令set,lpush,sadd redis-benchmark -h 127.0.0.1 -p 6379 -t set,lpush,sadd -c 100 -n 20000 # 案例:只查看测试报告结果,不看详细内容:-q redis-benchmark -h 127.0.0.1 -p 6379 -t set,lpush,sadd -c 100 -n 20000 -q
到此这篇关于redis--sds字符串与集合的底层实现原理的文章就介绍到这了,更多相关redis--sds字符串与集合的底层实现原理内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论