解决Redis Cluster模式下的排序问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决Redis Cluster模式下的排序问题相关的知识,希望对你有一定的参考价值。

通常的redis排序我们可以这么做:

比如按商品价格排序:sort goods_id_set by p_*_price

这样在非集群模式下是没问题的,但如果在集群模式下,就会报错:

技术分享

说是在集群模式下不能用sort的by子句,因为在集群模式下,上面的p_*_price匹配的key可能分布在不同的节点的slot中,所以无法做到排序。

那怎么办咧?别急,办法还是有的,我们就用 SortedSet

怎么用呢?很简单,看代码:

我们先添加几个商品,并赋上价格

zadd goods_prices 10 1 //商品id为1,价格为10元

zadd goods_prices 20 2 //商品id为2,价格为20元

zadd goods_prices 15 3 // 商品id为3,价格为15元

zadd goods_prices 5 4  // 商品id为4 价格为5元

然后排序:

1. zrange goods_prices 0,9999999 //按价格从低到高排序

2. zrevrange goods_prices 0,9999999 //按价格从高到低排序

打印结果:

1.  4,1,3,2

2.  2,3,1,4

然后再通过这些id去get商品信息就可以了

以上是关于解决Redis Cluster模式下的排序问题的主要内容,如果未能解决你的问题,请参考以下文章

高可用集群架构——redis的主从复制与哨兵模式,cluster

redis集群介绍与搭建(主从哨兵cluster集群)!

redis集群介绍与搭建(主从哨兵cluster集群)!

老司机带你玩转面试:Redis 集群模式 Redis Cluster

redis解决方案之三种集群模式的概念与部署

Redis cluster集群模式的原理