JAVA 多种减库存方案的效率问题

本文探讨了JAVA中四种不同的减库存方案:同步方法、乐观锁、数据库排他锁和Redis+Lua的效率。通过多线程测试,发现Redis+Lua方案速度最快,而同步方法效率最低。乐观锁和数据库排他锁在速度上优于同步方法,但在高并发下,乐观锁效率不如预期。测试结果显示,不同方案在不同并发场景下的平均响应时间差异显著。
摘要由CSDN通过智能技术生成

这里只做了一个减库存的操作,没有生成订单之类的操作,操作数据库使用的是JPA。
方案为别是:

  1. synchronized 同步方法
  2. 乐观锁
  3. for update 数据库排他锁
  4. redis+lua

方案一

@RestController
public class GoodsController {
   
    @Autowired
    GoodsDao goodsDao;
    
    @Transactional
    @GetMapping("/syn_stock")
    public synchronized String synStock(Integer id) {
   
        Optional<Goods> goodsOptional = goodsDao.findById(id);
        Goods goods = goodsOptional.get();
        int stock = goods.getStock();
        if (stock <= 0) {
   
            return "卖完了";
        }
        System.out.println("库存=" + stock);

        goods.setStock(stock - 1);
        goods = goodsDao.save(goods);
        System.out.println("库存成功减 1 数据库的库存为" + goods.getStock());

    }
 }

方案二

@RestController
public class GoodsController {
   
    @Autowired
    GoodsDao goodsDao;
    @Autowired
    private ApplicationContext applicationContext;

    /**
     * 减库存
     *
     * @param id
     * @return
     */
    @GetMapping("/stock")
    public String stock(Integer id) {
   
        ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
        GoodsController goodsController =(GoodsController) applicationContext.getBean("goodsController");

        Optional<Goods> goodsOptional = goodsDao.findById(id);
        int stock = goodsOptional.get().getStock();

        if (stock <= 0) {
   
            return "卖完了";
        }
        System.out.println("库存=
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值