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

一般的redis排序咱们能够这么作:redis

好比按商品价格排序:sort goods_id_set by p_*_pricespa

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

说是在集群模式下不能用sort的by子句,由于在集群模式下,上面的p_*_price匹配的key可能分布在不一样的节点的slot中,因此没法作到排序。排序

那怎么办咧?别急,办法仍是有的,咱们就用 SortedSetget

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

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

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

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

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

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商品信息就能够了

相关文章
相关标签/搜索