集成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;
}
}
/**
* 取值 - <rpop:非阻塞式>
* @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<Object> 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<Object> 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);
说明:
核心的功能是以上三部,具体场景需要结合自己的业务来进行处理。