Redis를 사용하여 순위 기능을 구현하는 방법

藏色散人
풀어 주다: 2020-08-13 11:45:24
앞으로
4524명이 탐색했습니다.

Redis Tutorial 칼럼에서는 Redis를 사용하여 순위 기능을 구현하는 방법을 소개하겠습니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

Redis를 사용하여 순위 기능을 구현하는 방법

순위 기능은 매우 일반적인 요구 사항입니다. Redis의 Ordered Set 기능을 사용하여 순위 목록을 구현하는 것은 빠르고 좋은 선택입니다.

"사용자 포인트 목록"과 같은 일반 순위가 효과적입니다. 효율성이 없고 항상 전체 순위를 기준으로 순위가 결정된다면 항상 목록의 최상위에 소수의 기존 사용자가 있을 수 있습니다. 신규 사용자에게는 정말 답답한 일입니다.

우선 '오늘의 포인트 목록'을 살펴보겠습니다. 정렬 규칙은 오늘 사용자가 추가한 새 포인트가 많은 것부터 적습니다.

그리고 사용자가 포인트를 추가하면 그날의 포인트 증가를 기록하는 주문 컬렉션을 운영하게 됩니다.
오늘이 2015년 4월 1일이고 UID 1인 사용자가 특정 작업으로 인해 5점을 얻었다고 가정합니다.
Redis 명령은 다음과 같습니다.

ZINCRBY rank:20150401 5 1
로그인 후 복사

다른 여러 사용자도 포인트를 추가했다고 가정합니다.

ZINCRBY rank:20150401 1 2
ZINCRBY rank:20150401 10 3
로그인 후 복사

현재 정렬된 세트 순위의 데이터를 살펴보세요: 20150401(withscores 매개변수를 사용하여 요소의 점수를 얻을 수 있습니다) ):

ZRANGE rank:20150401 0 -1 withscores
로그인 후 복사
1) "2"
2) "1"
3) "1"
4) "5"
5) "3"
6) "10"
로그인 후 복사

Follow 점수는 높은 것부터 낮은 것 순으로 상위 10개를 얻습니다.

ZREVRANGE rank:20150401 0 9 withscores
로그인 후 복사
1) "3"
2) "10"
3) "1"
4) "5"
5) "2"
6) "1"
로그인 후 복사

요소가 3개뿐이므로 이 데이터를 쿼리했습니다.

매일 그날의 포인트 순위를 기록하면 온갖 트릭이 담긴 다른 목록도 간단해집니다.
예: "어제 순위":

ZREVRANGE rank:20150331 0 9 withscores
로그인 후 복사

합집합을 사용하여 여러 날의 포인트 합을 구현하여 "지난주 순위" 실현:

ZUNIONSTORE rank:last_week 7 rank:20150323 rank:20150324 rank:20150325 rank:20150326 rank:20150327 rank:20150328 rank:20150329 WEIGHTS 1 1 1 1 1 1 1
로그인 후 복사

이렇게 하면 7일간의 포인트 기록이 주문된 세트에 병합됩니다. 순위:지난_주 . 가중치 계수 WEIGHTS 지정하지 않은 경우 기본값은 1입니다. 내용을 숨기지 않기 위해 일부러 적어봤습니다.
그러면 지난 주 순위 상위 10위를 조회하기 위한 정보는

ZREVRANGE rank:last_week  0 9 withscores
로그인 후 복사

"월간 목록", "분기별 목록", "연간 목록" 등입니다.

위 내용은 Redis를 사용하여 순위 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:cnblogs.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!