2分钟搞定redis实现消息队列

集成redis的pom依赖以及yml文件,可以参考我之前的博客,这里不再赘述。
实现redis消息队列,用到的是list数据类型,所以首先修改之前的redis配置文件:
1.RediTemplateUtil

   /**
     * list列表类型:先进后出栈形式,单个值插入
     * @param key
     * @param value
     * @return
     */
    public boolean lpush(String key, Object value) {
        try {
            redisTemplate.opsForList().leftPush(key, value);
            return true;
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }
    
    /**
     * 取值 - 
     * @param key 键
     * @return
     */
    public Object rpop(String key) {
        try {
            return redisTemplate.opsForList().rightPop(key);
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 查看值
     * @param key 键
     * @param start 开始
     * @param end 结束 0 到 -1代表所有值
     * @return
     */
    public List lrange(String key, long start, long end) {
        try {
            return redisTemplate.opsForList().range(key, start, end);
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
     /**
     * 清空所有数据
     * @param
     * @return
     */
    public void ltrim(String key,long var2, long var4) {
        try {
             redisTemplate.opsForList().trim(key,var2,var4);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
 }
 
  

2.入栈

//放入消息队列
boolean lpush = redisTemplateUtil.lpush(redis的缓存key, 放入消息队列的内容);
log.info("把请求算法的数据放入redis,lpush结果为:{}",lpush);

3.出栈

//先判断是否存在
List lrange = redisTemplateUtil.lrange(redis的缓存key, 0, -1);
if(lrange!=null && lrange.size()>0){
Object lpop = redisTemplateUtil.rpop(redis的缓存key);
log.info("从redis中拉取的数据为:{}",lpop);
 
  

4.清空队列内的数据

redisTemplateUtil.ltrim(redis的缓存key,1,0);

说明:
核心的功能是以上三部,具体场景需要结合自己的业务来进行处理。

你可能感兴趣的:(redis)