背景:
做商品支付的开发过程中,一个必须考虑到的环节:用户在点击下单购买,同时也点击了支付,这时候由于各种原因,用户长时间未支付,对于库存有限的商品来说,一般会将当前订单的商品库存锁定一段时间,这段时间一过,还未支付,库存自动回库,同时修改支付状态,可以参照下12306的买票过程,对于这样一种需求,我们有什么开发成本低的方案呢?
方案:
如果你的后端是java开发的,那搞个schedule定时任务到时间了去查一下是否支付成功,如果没有支付,回库,改状态,也比较简单。
如果后端是php开发的呢,php搞不了多线程啊,只能linux开crontab 任务了,写个php脚本,定时扫订单吧。
今天提供的一种思路是利用redis的过期机制,以及过期回调来实现这个功能,对redis底层的操作封装,java,php都有支持
已下以php为例简要介绍实现方法
redis的过期回调这个功能很关键,需要在redis.conf中开启配置
notify-keyspace-events "Ex"
php扩展redis.php已经封装好了回调方法
public function psubscribe( $patterns, $callback ) {}
调用:
$redis_xx->psubscribe(array('__keyevent@0__:expired'), 'psCallback');
function psCallback($redis_xx, $pattern, $chan, $msg){
$msg 为你设置的key,可以传订单ID过来,回调的时候用订单ID去查询付款状态,同时判断是否需要库存回库
}
这个回调监听的脚本需要一直运行在后端的,否则redis的key过期后是无法通知到的,也就无法调用你的回调方法,我们可以用linux提供的命令 nohup xxx.php & 当前脚本回转到后端以进程方式运行,同时回生成一个叫nohup.out的文件用来记录日志,至此我们的方案介绍完毕
最近上架了款微信小游戏,欢迎大家来体验,多多提意见,微信扫一扫下面小程序码即可体验