(Redis使用系列) Springboot 使用redis的List数据结构实现简单的排队功能场景 九

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: (Redis使用系列) Springboot 使用redis的List数据结构实现简单的排队功能场景 九

前言



如题,该篇实践教程就是简单的抛砖引玉,通过实现一个简单的排队场景,带着大家熟悉下 redis里list数据结构的相关操作。



正文



在开始编码前,我们先简单了解下该篇实践教程实现 排队场景,


包括哪些功能:


1. 正常排队


2.队伍总人数


3.队伍信息


4.某人离开队伍


5.正常排队完离开队伍


6.某人在队伍的所在位置,前面人数,后面人数


7.插队 (道德不允许,咱们只是做个例子)



开始编码:



ps :怎么整合redis这篇文章就不介绍了,如果还不会的可以看我的这个系列的教程。



为了方便咱们的演示,直接通过写接口调接口的方式。


创建一个MyTestController.java,注入一下RedisTemplate:


/**
 * @Author : JCccc
 * @CreateTime : 2020/3/27
 * @Description :
 **/
@Controller
@RequestMapping("/test")
public class MyTestController {
    @Autowired
    private RedisTemplate redisTemplate;
}


1. 正常排队


    /**
     * 加入队伍
     * @param userId
     */
    @ResponseBody
    @GetMapping("/addQueue")
    public void addQueue(@RequestParam("userId") String userId) {
      //  redisTemplate.opsForList().leftPush("myQueue",userId);
        redisTemplate.opsForList().rightPush("yourQueue",userId);
    }


可以看到这个接口里面,我的代码有一行注释的,其实两行低吗都是往队伍里面去添加数据达到 排队加入队伍的功能。


而通过数据顺序来说,我选择使用rightPush,这样更能容易理解排队的原则,先进先出。

 

那么我们开始调用接口 /addQueue ,看看效果:


image.png


可以看到redis里面的数据,01 妥妥地加入到了队伍:


 image.png


重复上面的操作,模拟出一个小队列数据,将02,03,04,05 也按顺序排队加入到队伍里,结果如:


image.png


2.队伍总人数


    /**
     * 队伍总人数
     */
    @ResponseBody
    @GetMapping("/queueCount")
    public String queueCount() {
        Long listSize = redisTemplate.opsForList().size("yourQueue");
       return "队伍总人数:"+listSize;
    }


调用接口,查看队伍总人数:


image.png


3.队伍信息


    /**
     * 队伍详情
     */
    @ResponseBody
    @GetMapping("/queueData")
    public String queueData() {
        List listData = redisTemplate.opsForList().range("yourQueue", 0, -1);
        return listData.toString();
    }


调用接口,查看队伍详情:


image.png


4.某人离开队伍


    /**
     * 离开队伍
     * @param userId
     */
    @ResponseBody
    @GetMapping("/leaveQueue")
    public void leaveQueue(@RequestParam("userId") String userId) {
        Long removeNum = redisTemplate.opsForList().remove("yourQueue", 0, userId);
        System.out.println(removeNum);
    }


这个接口里面使用的方法,第二个参数,需要注意:


对于list数据其实是允许重复的,但是我们模拟的队列数据,给用户分配的userId保持唯一。


但是原有的remove方法使兼容了重复数据移除的场景,


当传入 0: 移除整个队列里的 目标值 ,也就是录入传入userId是01,


那么有一个也移除,有N个也移除,反正保证干干净净。


当传入小于0的数,如-1或者传入大于0的数,如1: 就是不同顺序去检查这个队伍,直到碰到第一个目标值,进行删除。



调用接口,模拟 03 这个用户离开队伍:


image.png


结果:


image.png


5.正常排队完离开队伍


    /**
     * 默认离队,先进先出
     */
    @ResponseBody
    @GetMapping("/defaultLeaveQueue")
    public void defaultLeaveQueue() {
        redisTemplate.opsForList().leftPop("yourQueue");
    }


当前队伍里面01排在最前面,所以当调用接口时,默认排完队离开的就是01,先进先出:


image.png


结果:


image.png


6.某人在队伍的所在位置, 前面人数,后面人数


    /**
     * 查看我自己的队列位置
     * @param userId
     */
    @ResponseBody
    @GetMapping("/getMyPosition")
    public void getMyPosition(@RequestParam("userId") String userId){
        List listData = redisTemplate.opsForList().range("yourQueue", 0, -1);
        int myPositionBeforeNum = listData.indexOf(userId);
        int myPositionNum = listData.indexOf(userId)+1;
        int size=listData.size();
        System.out.println("所在位置前面人数:"+myPositionBeforeNum);
        System.out.println("所在位置:"+myPositionNum);
        System.out.println("所在位置后面人数:"+(size-myPositionNum));
    }


调用接口,查看04所在队伍的位置,以及他前面还有多少人,后面还有多少人:


image.png

结果:

image.pngimage.png


7.插队  


ps:有时候业务需要插队场景还是有需要的


    /**
     * 野蛮插队
     * @param userId
     * @param toUserId
     */
    @ResponseBody
    @GetMapping("/savageAction")
    public void savageAction(@RequestParam("userId") String userId ,@RequestParam("toUserId") String toUserId,@RequestParam("type") String type){
            //userId 插队人
            //toUserId 被插队人
            //before 插前面
            //after 插后面
           if ("before".equals(type)){
               redisTemplate.opsForList().leftPush("yourQueue",toUserId,userId);
             }
           if ("after".equals(type)){
               redisTemplate.opsForList().rightPush("yourQueue",toUserId,userId);
           }
    }


插队有分插前面和后面,调用接口,模拟一个新用户 2020 插队,插入到了04这个用户前面:


image.png


结果:


image.png


再调用接口,模拟一个新用户 3003 插队,插入到了2020这个用户后面:


image.png


结果:


image.png


该篇就到此。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2月前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
这篇文章是关于如何在SpringBoot应用中整合Redis并处理分布式场景下的缓存问题,包括缓存穿透、缓存雪崩和缓存击穿。文章详细讨论了在分布式情况下如何添加分布式锁来解决缓存击穿问题,提供了加锁和解锁的实现过程,并展示了使用JMeter进行压力测试来验证锁机制有效性的方法。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
|
2月前
|
编解码 NoSQL Java
使用Spring Boot + Redis 队列实现视频文件上传及FFmpeg转码的技术分享
【8月更文挑战第30天】在当前的互联网应用中,视频内容的处理与分发已成为不可或缺的一部分。对于视频平台而言,高效、稳定地处理用户上传的视频文件,并对其进行转码以适应不同设备的播放需求,是提升用户体验的关键。本文将围绕使用Spring Boot结合Redis队列技术来实现视频文件上传及FFmpeg转码的过程,分享一系列技术干货。
88 3
|
2月前
|
消息中间件 NoSQL Redis
redis数据结构-List
redis数据结构-List
34 1
|
25天前
|
消息中间件 存储 NoSQL
剖析 Redis List 消息队列的三种消费线程模型
Redis 列表(List)是一种简单的字符串列表,它的底层实现是一个双向链表。 生产环境,很多公司都将 Redis 列表应用于轻量级消息队列 。这篇文章,我们聊聊如何使用 List 命令实现消息队列的功能以及剖析消费者线程模型 。
68 20
剖析 Redis List 消息队列的三种消费线程模型
|
5天前
|
消息中间件 存储 NoSQL
4)深度解密 Redis 的列表(List)
4)深度解密 Redis 的列表(List)
10 1
|
8天前
|
JSON NoSQL Java
redis的java客户端的使用(Jedis、SpringDataRedis、SpringBoot整合redis、redisTemplate序列化及stringRedisTemplate序列化)
这篇文章介绍了在Java中使用Redis客户端的几种方法,包括Jedis、SpringDataRedis和SpringBoot整合Redis的操作。文章详细解释了Jedis的基本使用步骤,Jedis连接池的创建和使用,以及在SpringBoot项目中如何配置和使用RedisTemplate和StringRedisTemplate。此外,还探讨了RedisTemplate序列化的两种实践方案,包括默认的JDK序列化和自定义的JSON序列化,以及StringRedisTemplate的使用,它要求键和值都必须是String类型。
redis的java客户端的使用(Jedis、SpringDataRedis、SpringBoot整合redis、redisTemplate序列化及stringRedisTemplate序列化)
|
8天前
|
存储 JSON NoSQL
redis基本数据结构(String,Hash,Set,List,SortedSet)【学习笔记】
这篇文章是关于Redis基本数据结构的学习笔记,包括了String、Hash、Set、List和SortedSet的介绍和常用命令。文章解释了每种数据结构的特点和使用场景,并通过命令示例演示了如何在Redis中操作这些数据结构。此外,还提供了一些练习示例,帮助读者更好地理解和应用这些数据结构。
redis基本数据结构(String,Hash,Set,List,SortedSet)【学习笔记】
|
1天前
|
存储 NoSQL Java
Spring Boot项目中使用Redis实现接口幂等性的方案
通过上述方法,可以有效地在Spring Boot项目中利用Redis实现接口幂等性,既保证了接口操作的安全性,又提高了系统的可靠性。
6 0
|
2月前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
这篇文章介绍了如何在SpringBoot项目中整合Redis,并探讨了缓存穿透、缓存雪崩和缓存击穿的问题以及解决方法。文章还提供了解决缓存击穿问题的加锁示例代码,包括存在问题和问题解决后的版本,并指出了本地锁在分布式情况下的局限性,引出了分布式锁的概念。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
|
2月前
|
NoSQL Java Redis
Redis6入门到实战------ 八、Redis与Spring Boot整合
这篇文章详细介绍了如何在Spring Boot项目中整合Redis,包括在`pom.xml`中添加依赖、配置`application.properties`文件、创建配置类以及编写测试类来验证Redis的连接和基本操作。
Redis6入门到实战------ 八、Redis与Spring Boot整合
下一篇
无影云桌面