当时接到了一个商城的需求,当时涉及到订单的超时,根据网上的教程说是使用redis的 过期事件来做,,按照教程来写,不过确实很有用,不错不错,,当我心高彩烈的找领导说把服务器上的redis通知打开,期间可能会重启reids。我靠,当然人家不同意了,redis用了那么久了,而且怎么能说重启就重启呢,,怪我怪我,开始做的时候没有考虑那么周全。不过我是一个有想法,开心的程序员。不一会又来了一个实现思路。同时觉得过期的这种不是很好处理,reids过期会把key删除,,所以如果临近过期时间给用户发送提醒短信的时候就不好搞。这个很简单,听我娓娓道来:
首先到提交订单,提交完订单之后讲订单时间存到redis
redisService.setKey("shop_order:"+shopOrder.getId(), DateUtil.formatDateTimeByTime(shopOrder.getCreateTime()));
我是这样写的,,我在redis存储的时候加统一的前缀,方便后面取值,然后新建一个定时任务的项目,每分钟开始去查询时间和现在的时间进行比对,扩展性强,但是适用与数据量不是很大的时候:
SimpleDateFormat sDateFormat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
//搜索已shop_order:开头的key
Set<String> keys = redisService.getAllKey("shop_order:*");
List<String > delKey = Lists.newArrayList();
if (keys != null && keys.size() >0){
for (String key : keys){
String value = (String) redisService.getValue(key);
Date orderDate = null;
Date nowDate = new Date();
try {
orderDate = sDateFormat.parse(value);
} catch (ParseException e) {
e.printStackTrace();
}
Calendar calendar = Calendar.getInstance();
calendar.setTime(orderDate);
calendar.add(Calendar.MINUTE,30);
orderDate = calendar.getTime();
if (orderDate.getTime() < nowDate.getTime()){
//超时处理
delKey.add(key);
}
}
//删除redis key
redisService.deleteKey(delKey);
}