12.29 redis实现一个简单排行榜

项目描述:Redis实现的实时排行榜系统

本项目是一个基于 Spring Boot 和 Redis 的实时排行榜系统,利用 Redis 的有序集合(ZSet)数据结构高效地管理用户分数和排名。 用于Redis中Zset数据结构学习

Service

java 复制代码
package org.example.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;

import java.util.Set;

@Service
public class LeaderboardService {

    private static final String LEADERBOARD_KEY = "game:leaderboard";

    @Autowired
    private StringRedisTemplate redisTemplate;

    // 增加或更新用户分数
    public void addOrUpdateScore(String userId, double score) {
        redisTemplate.opsForZSet().addIfAbsent(LEADERBOARD_KEY,userId,score);
    }


    // 获取用户排名(Redis 排名从 0 开始)
    public Long getUserRank(String userId) {
        Long l = redisTemplate.opsForZSet().reverseRank(LEADERBOARD_KEY, userId);
        if(l==null)return null;
        return l+1;
    }

    // 获取用户分数
    public Double getUserScore(String userId) {
        Double score = redisTemplate.opsForZSet().score(LEADERBOARD_KEY, userId);
        if(score==0)
            return null;
        return score;
    }

    // 获取排行榜前 N 名
    public Set<String> getTopUsers(int topN) {
        return   redisTemplate.opsForZSet().reverseRange(LEADERBOARD_KEY, 0, topN - 1);

    }
}

下面是control

java 复制代码
package org.example.control;

import org.example.service.LeaderboardService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

@RestController
@RequestMapping("/leaderboard")
public class LeaderboardController {

    @Autowired
    private LeaderboardService leaderboardService;

    // 增加或更新用户分数
    @PostMapping("/add")
    public String addScore(@RequestParam String userId, @RequestParam double score) {
        leaderboardService.addOrUpdateScore(userId, score);
        return "Score added/updated successfully!";
    }

    @PostMapping("/addBatch")
    public String addScoresBatch(@RequestBody List<Map<String, Object>> users) {
        for (Map<String, Object> user : users) {
            String userId = (String) user.get("userId");
            double score = Double.parseDouble(user.get("score").toString());
            leaderboardService.addOrUpdateScore(userId, score);
        }
        return "Batch scores added/updated successfully!";
    }
    // 获取用户排名和分数
    @GetMapping("/rank/{userId}")
    public Map<String, Object> getUserRank(@PathVariable String userId) {
        Long rank = leaderboardService.getUserRank(userId);
        Double score = leaderboardService.getUserScore(userId);

        return Map.of(
                "userId", userId,
                "rank", rank,
                "score", score
        );
    }

    // 获取排行榜前 N 名
    @GetMapping("/top/{topN}")
    public Map<String, Object> getTopUsers(@PathVariable int topN) {
        Set<String> topUsers = leaderboardService.getTopUsers(topN);
        
        // 获取每个用户的分数
        Map<String, Object> leaderboard = topUsers.stream()
                .collect(Collectors.toMap(
                        userId -> userId,
                        userId -> leaderboardService.getUserScore(userId)
                ));

        return Map.of("leaderboard", leaderboard);
    }
}
相关推荐
tekin28 分钟前
Go、Java、Python、C/C++、PHP、Rust 语言全方位对比分析
java·c++·golang·编程语言对比·python 语言·php 语言·编程适用场景
qq_5298353528 分钟前
Redis作为缓存和数据库的数据一致性问题
数据库·redis·缓存
李长渊哦2 小时前
Java 虚拟机(JVM)方法区详解
java·开发语言·jvm
陌殇殇3 小时前
002 SpringCloudAlibaba整合 - Feign远程调用、Loadbalancer负载均衡
java·spring cloud·微服务
猎人everest3 小时前
SpringBoot应用开发入门
java·spring boot·后端
知初~4 小时前
出行项目案例
hive·hadoop·redis·sql·mysql·spark·database
山猪打不过家猪6 小时前
ASP.NET Core Clean Architecture
java·数据库·asp.net
AllowM6 小时前
【LeetCode Hot100】除自身以外数组的乘积|左右乘积列表,Java实现!图解+代码,小白也能秒懂!
java·算法·leetcode
不会Hello World的小苗6 小时前
Java——列表(List)
java·python·list
二十七剑7 小时前
jvm中各个参数的理解
java·jvm