电商项目之如何扣减库存

2023-10-09 04:04
文章标签 项目 库存 电商 扣减

本文主要是介绍电商项目之如何扣减库存,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

文章目录

  • 1 问题背景
  • 2 前言
  • 3 扣减库存的三种方案
    • 3.1 下单减库存
    • 3.2 付款减库存
    • 3.3 预扣库存
  • 4 如何解决恶意买家下单的问题
    • 4.1 限制用户下单的数量
    • 4.2 标识恶意买家
  • 5 实战:具体实现思路

1 问题背景

今天研究一下亿级流量的电商网站是怎么扣减库存
参考自:浅析「扣减库存」的方案设计

2 前言

本文旨在阐述生产环境如何在高并发的场景下可靠地扣减库存,有其他解决方案的伙伴可以在评论中分享出来。

3 扣减库存的三种方案

常规的支付链路是下单->创建订单->支付

3.1 下单减库存

用户下单时减库存

优点:实时扣减库存,避免支付时因库存不足减库存的问题
缺点:恶意买家大量下单,但不付款,导致真正想买的人买不到

3.2 付款减库存

下单时不会立即减库存,而是等到支付时才会减库存

优点:防止恶意买家大量下用光库存,避免下单扣库存的缺点
缺点:下单页面不是最新的库存,假如支付的订单数超过库存数,则支付失败

3.3 预扣库存

下单后预扣库存,超过一定时间后,库存释放。若超过时间后再支付,如果没有库存,则支付失败

优点:实时减库存,缓解恶意买家大量下单的问题,超过一定时间未支付则释放库存
缺点:在一定时间内,恶意买家大量下单仍可以将库存用完。

4 如何解决恶意买家下单的问题

在库存方面有恶意买家下单占用库存的问题,也会有恶意买家下单后拒付的问题,这种拒付会提高卖家收款账号被风控的概率。因此无论是在库存方面还是在支付方面,都需要解决恶意买家下单的问题

4.1 限制用户下单的数量

优点:限制恶意买家下单
缺点:非恶意买家会被限制下单,销量会降低

4.2 标识恶意买家

通过历史订单的情况、买家设备指纹(user_agent等),来标识恶意买家。缺点是可能存在误标。

5 实战:具体实现思路

  • 商品的库存用Redis的hash结构存起来,通过incrby指令加减库存;
  • 扣减库存时,采用预扣库存的思路,先扣减Redis中的库存,剩余库存的数量大于0,表明预扣成功,否则回滚库存(Redis要回滚库存,然后抛异常,不持久化数据库库存);
  • 如果Redis预扣库存成功,则持久化库存到数据库,否则抛异常。更新数据库的库存时,直接使用update语句update t_sku_inventory set inventory = inventory + quantity where id = xxx;

流程图如下图所示:

在这里插入图片描述

这篇关于电商项目之如何扣减库存的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/170211

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结

Spring Boot项目如何使用外部application.yml配置文件启动JAR包

《SpringBoot项目如何使用外部application.yml配置文件启动JAR包》文章介绍了SpringBoot项目通过指定外部application.yml配置文件启动JAR包的方法,包括... 目录Spring Boot项目中使用外部application.yml配置文件启动JAR包一、基本原理

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav