使用redis的list存储数据实现队列功能

在项目开发中,遇到一个问题,用户在登录时,注册,激活等各种操作时(注:由于业务需求,用户的状态比较多),日志文件中会产生大量的SQL语句,日志文件膨胀过快!所以就把用户的一些譬如一些保存登录激活操作时,采用异步操作,将用户的信息保存在redis中。设置定时器,在用户不太活跃的时间段,再对数据进行落地操作!具体代码如下:

第二步:放入缓存的具体操作(Java使用jedis客户端)

public void saveUserToQueue(User user, String queueName) {
if (user == null)
return;
try {

//使用rpush是朝list集合的尾部顺序插入数据,queueName作为redis的key
commonRedisService.rpush(queueName, JsonUtil.Object2Json(user));
} catch (TimeoutException e) {
logger.info("save User To Queue[{}] failed: !", queueName, e);
}
}

第三部:job操作对数据进行落地

使用redis的lpop方法,从list的头部拿出数据,这样就实现了先进先出的操作!

第四步:quartz的配置

1、在spring的bean.xml中配置一个job

 

2、定义触发器

3、将触发器加入到quartz中

 

结束。。。。。。

注:由于技术限制,本文重点在于思想上的操作,如有问题,还请指教!

posted @ 2016-04-13 10:13  计冰冰  阅读(3675)  评论(0编辑  收藏  举报