解決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商品信息就能夠了

相關文章
相關標籤/搜索