Redis应用之SortedSet的使用

前言:相对来说我们是比较深度使用redis的,在推荐瀑布流和排行榜等好多的场景我们主要是用的是SortedSet,今天来说一说SortedSet

redis集群监控

一、基本的用法

  1. 插入数据,常用的有ZADDZINCRBY

    • 使用方法Long zadd(byte[] key, double score, byte[] member)插入数据,比我们的推荐场景中,根据用户的行为数据,推荐出来的数据会存放到redis中,就是调用这个方法,插入要推荐的数据
    • 使用方法Double zincrby(byte[] key, double score, byte[] member)对已有的数据的score的值进行增减,比如我们的搜索词排行,用户输入一个搜索词之后,经历一定的清洗后会把对应的词存入redis中,score记入1,以后每多搜索一次,调用ZINCRBY对这个搜索词加1
  2. 删除数据,常用的有ZREM,ZREMRANGEBYSCORE

    • 使用方法Long zrem(byte[] key, byte[]... member)删除集合中给定的元素,可以是多个,不存在的成员将被忽略
    • 使用方法Long zremrangeByScore(byte[] key, double start, double end)删除集合中给定score区间的元素,其中start可以是’-inf’,end可以是‘+inf’
  3. 查询数据,常用的有ZRANGE,ZRANGEBYSCORE,ZREVRANGE,ZREVRANGEBYSCORE

    • 使用方法Set<byte[]> zrange(byte[] key, long start, long end)返回有序集 key 中,指定区间内的成员,其中成员的位置按 score 值递增(从小到大)来排序
    • 使用方法Set<byte[]> zrevrange(byte[] key, long start, long end)返回有序集 key 中,指定区间内的成员,其中成员的位置按 score 值递增(从大到小)来排序
    • 使用方法Set<byte[]> zrangeByScore(byte[] key, double min, double max)返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列
    • 使用方法Set<byte[]> zrevrangeByScore(byte[] key, double min, double max)返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从大到小)次序排列
    • 使用方法Set<Tuple> zrangeByScoreWithScores(byte[] key, double min, double max)返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员及score。有序集成员按 score 值递增(从小到大)次序排列

二、注意点

  1. ZINCRBY可以对当前键值的score进行增减操作,减的操作传入负数的score值即可,如果插入的数据不存在,当前key不存在,score即为传入的score,如果key存在则当前的score加上redis本身存在的score为最终的结果
  2. 查询数据,慎用全量的操作,尤其是在不确定当前的键中的结果集合的大小的情况,如果一定要用最好先判断一下当前的键中结果集合的大小,根据大小分批次获取,一般建议一次查询返回的数据量在10KB一下,不过到几百KB也是可以接受的,如果再大的话,需要考虑一下性能

三、问题

  1. redis如何保证查询的数据的顺序性?
    通过查看源代码,我们可以知道,redis的返回的结果集使用的是LinkedHashSet,保存返回结果集合的
    private Set<Tuple> getTupledSet() {
    	checkIsInMultiOrPipeline();
    	List<String> membersWithScores = client.getMultiBulkReply();
    	if (membersWithScores == null) {
    	  return Collections.emptySet();
    	}
    	if (membersWithScores.isEmpty()) {
    	  return Collections.emptySet();
    	}
    	Set<Tuple> set = new LinkedHashSet<Tuple>(membersWithScores.size() / 2, 1.0f);
    	Iterator<String> iterator = membersWithScores.iterator();
    	while (iterator.hasNext()) {
    	  set.add(new Tuple(iterator.next(), Double.valueOf(iterator.next())));
    	}
    	return set;
      }
    
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值