miqiu的分布式锁(二):实战——用JMeter验证JVM锁能否解决MySQL超卖问题

miqiu的分布式锁二:实战------用JMeter验证JVM锁能否解决MySQL超卖问题

实验背景

在秒杀场景中,超卖问题是典型的并发编程挑战。本文通过JMeter压测工具,验证基于JVM的两种锁机制(synchronized/ReentrantLock)对MySQL库存操作的防护效果。


实验一:内存库存操作验证

1.1 无锁场景

java 复制代码
public void deduct() {
    stock.setStock(stock.getStock() - 1);
    System.out.println("库存余量:" + stock.getStock());
}

压测结果(100线程×50次循环):

  • 平均响应时间:3ms
  • 吞吐量:2217/sec
  • 最终库存:-89(严重超卖)

1.2 synchronized锁方案

java 复制代码
public synchronized void deduct() {
    stock.setStock(stock.getStock() - 1);
    System.out.println("库存余量:" + stock.getStock());
}

压测结果对比

  • 平均响应时间 ↗ 25ms(733%增长)
  • 吞吐量 ↘ 396/sec(82%下降)
  • 最终库存 ✅ 0(完美解决)

1.3 ReentrantLock方案

java 复制代码
private final ReentrantLock lock = new ReentrantLock();

public void deduct() {
    lock.lock();
    try {
        stock.setStock(stock.getStock() - 1);
        System.out.println("库存余量:" + stock.getStock());
    } finally {
        lock.unlock();
    }
}

性能表现

  • 平均响应时间:22ms
  • 吞吐量:440/sec
  • 最终库存 ✅ 0

实验二:真实MySQL库存操作

2.1 无锁数据库操作

java 复制代码
public void deduct() {
    Stock stock = stockMapper.selectByProductCode("1001");
    if(stock != null && stock.getCount() > 0) {
        stock.setCount(stock.getCount() - 1);
        stockMapper.updateById(stock);
    }
}

压测结果

  • 平均响应时间:249ms
  • 吞吐量:394/sec
  • 最终库存:4900(严重超卖)

2.2 ReentrantLock防护方案

java 复制代码
private final ReentrantLock lock = new ReentrantLock();

public void deduct() {
    lock.lock();
    try {
        Stock stock = stockMapper.selectByProductCode("1001");
        if(stock != null && stock.getCount() > 0) {
            stock.setCount(stock.getCount() - 1);
            stockMapper.updateById(stock);
        }
    } finally {
        lock.unlock();
    }
}

验证结果

  • 平均响应时间 ↗ 623ms(151%增长)
  • 吞吐量 ↘ 158/sec(60%下降)
  • 最终库存 ✅ 0(正确扣减)

关键结论

  1. 防护有效性

    JVM级锁能有效解决单机部署下的超卖问题,确保库存操作的原子性

  2. 性能代价

    synchronized/ReentrantLock均造成吞吐量显著下降,响应时间成倍增加

  3. 架构局限

    • 仅适用于单服务实例场景
    • 分布式部署时不同JVM实例的锁相互不可见
    • 数据库连接池耗尽风险(长时间持锁)

后续方向

通过本实验验证了JVM锁的单机有效性,但分布式场景需要更强大的锁机制。下一篇将研究jvm锁的失效情况

相关推荐
猫头虎1 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
wgslucky1 小时前
jdk17 配置jvm参数中gc的日志及控制日志数量和大小
jvm·gc·-xlog
qq_12498707534 小时前
基于Hadoop的信贷风险评估的数据可视化分析与预测系统的设计与实现(源码+论文+部署+安装)
大数据·人工智能·hadoop·分布式·信息可视化·毕业设计·计算机毕业设计
Coder_Boy_6 小时前
基于Spring AI的分布式在线考试系统-事件处理架构实现方案
人工智能·spring boot·分布式·spring
痴儿哈哈6 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
袁煦丞 cpolar内网穿透实验室7 小时前
远程调试内网 Kafka 不再求运维!cpolar 内网穿透实验室第 791 个成功挑战
运维·分布式·kafka·远程工作·内网穿透·cpolar
人间打气筒(Ada)7 小时前
GlusterFS实现KVM高可用及热迁移
分布式·虚拟化·kvm·高可用·glusterfs·热迁移
xu_yule7 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式
野犬寒鸦12 小时前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
難釋懷12 小时前
分布式锁的原子性问题
分布式