利用Redis保证订单的幂等性(订单幂等性 redis)
随着互联网平台越来越普及,用户对重复点击订单这一操作行为要求也在不断加大,否则就会造成订单的重复提交,显然这是不能接受的。同时,由于移动端的交互逻辑和复杂性,重复点击订单的操作行为也无法完全避免。
在保证订单的幂等性方面,Redis的使用明显可以提高效率。将用户的订单ID存储在Redis中,在验证重复提交订单前先进行查询:如果存在,则已经成功提交订单,此次订单将不再进行提交;若不存在,则提交订单,并将订单ID存储到Redis中。代码如下:
String orderid = getOrderId();
// 查询是否已提交订单
boolean exists = jedis.exists(orderid);
if(exists){
return "订单已提交,不能重复提交!";
}
// 以下对订单进行操作
// 执行其它业务逻辑 。。。
// 执行成功
// 将订单ID记录到Redis中,以保证订单的幂等性
jedis.setex(orderid, EXPIRE_TIME, orderid);
综上所述,Redis通过在客户端及服务端暂存订单ID,以达到确保每个订单ID只被提交1次的目的。同时,Redis可以实时获取数据,从而保证效率;同时,相比于传统RDBMS技术,应用Redis可以提高数据访问效率,从而改善用户体验。
香港服务器首选后浪云,2H2G首月10元开通。
后浪云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
版权声明:
作者:后浪云
链接:https://www.idc.net/help/65095/
文章版权归作者所有,未经允许请勿转载。
THE END