순위 기능은 매우 일반적인 요구 사항입니다. Redis의 정렬된 컬렉션 기능을 사용하여 순위를 구현하는 것은 빠르고 좋은 선택입니다.
"사용자 포인트 목록"과 같은 일반 순위가 효과적입니다. 효율성이 없고 항상 전체 순위를 기준으로 순위가 결정된다면 항상 목록의 최상위에 소수의 기존 사용자가 있을 수 있습니다. 신규 사용자에게는 정말 답답한 일입니다.
먼저 '오늘의 포인트 목록'을 살펴보겠습니다. 정렬 규칙은 오늘 사용자가 추가한 새 포인트가 많은 것부터 적습니다.
그리고 사용자가 포인트를 추가하면 그날의 포인트 증가분을 기록하는 주문 컬렉션을 운영하게 됩니다.
오늘이 2015년 4월 1일이고 UID 1인 사용자가 특정 작업으로 인해 5점을 얻었다고 가정합니다.
Redis 명령은 다음과 같습니다.
ZINCRBY 순위:20150401 5 1
다른 여러 사용자도 포인트를 추가했다고 가정합니다.
ZINCRBY 순위:20150401 1 2ZINCRBY 순위:20150401 10 3
보세요 이제 정렬된 세트 순위:20150401의 데이터(withscores 매개변수를 사용하여 요소의 점수를 얻을 수 있음):
ZRANGE 순위:20150401 0 -1 withscores1) "2"2) "1"3) "1 "4) "5 "5) "3"6) "10"
#p#Paging title#e#
점수에 따라 높은 순으로 상위 10위 획득:
ZREVRANGE 순위:20150401 0 9 withscores1) "3"2) "10"3) "1"4) "5"5) "2"6) "1"
요소가 3개뿐이므로 이 데이터를 쿼리했습니다.
오늘의 포인트 순위 목록이 매일 기록된다면, 다양한 트릭이 담긴 다른 목록도 간단해질 것입니다.
예: "어제 순위":
ZREVRANGE 순위:20150331 0 9 withscores
Union을 사용하여 여러 날에 대한 포인트 합계를 달성하여 "지난 주 순위"를 달성합니다.
ZUNIONSTORE 순위:last_week 7 순위:20150323 순위:20150324 순위:20150325 순위:20150326 순위:20150327 순위:20150328 순위:20150329 WEIGHTS 1 1 1 1 1 1 1
이렇게 7일간의 점수 기록이 정렬된 세트 순위에 병합됩니다. :지난주. 가중치 계수 WEIGHTS 지정하지 않은 경우 기본값은 1입니다. 내용을 숨기지 않기 위해 일부러 적어봤습니다.
그러면 지난 주 순위 상위 10위를 조회하기 위한 정보는 다음과 같습니다.
ZREVRANGE 순위:last_week 0 9 withscores#p#Paging title#e#
"월별 순위", "분기별 순위", "연간 순위" "등. 등등.
다음은 PHP 버전의 간단한 구현입니다. Redis를 사용하려면 PHP 확장 PhpRedis가 필요하며 코드는 처리 시간을 위해 Carbon 라이브러리도 필요합니다. 코드의 양이 매우 적어서 언급하지 않겠습니다.
<?php namespace BlogRedis; use Redis; use CarbonCarbon;class Ranks { const PREFIX = 'rank:'; protected $redis = null; public function __construct(Redis $redis) { $this->redis = $redis; } public function addScores($member, $scores) { $key = self::PREFIX . date('Ymd'); return $this->redis->zIncrBy($key, $scores, $member); } protected function getOneDayRankings($date, $start, $stop) { $key = self::PREFIX . $date; return $this->redis->zRevRange($key, $start, $stop, true);