当前位置: 首页 > news >正文

mybatis 高并发查询性能问题

场景: 使用Mybatis (3.5.10)@SelectProvider注解执行动态sql 在高并发查询时 QPS 很低

问题复现

  • mybatis 配置 (getOfflineConfigSqlTemplate 该方法返回的是动态sql )
    在这里插入图片描述

  • 压测结果

在这里插入图片描述

  • 观察线程阻塞情况
    在这里插入图片描述

  • 此时的QPS 在 80 左右

通过测试结果发现是mybatis 框架的问题 。使用原生的jdbc 连接池执行 ,对代码进行简单改造如下

  • 将注解执行sql 逻辑 换成 jdbc 连接池方式
    在这里插入图片描述

  • 相同压力相同资源下 再次进行压测 观察结果 :

  • 线程无阻塞
    在这里插入图片描述

  • QPS 从80 提升至 460

结论 : mybatis 动态sql 适合在非高并发查询场景下使用 。

http://www.lryc.cn/news/249867.html

相关文章:

  • 我在Vscode学OpenCV 图像处理一(阈值处理、形态学操作【连通性,腐蚀和膨胀,开闭运算,礼帽和黑帽,内核】)
  • Yolov8实现瓶盖正反面检测
  • GAN:WGAN前作
  • 数据库应用:MongoDB 文档与索引管理
  • Python批处理PDF文件,PDF附件轻松批量提取
  • Python可迭代对象排序:深入排序算法与定制排序
  • 基于matlab的图像去噪算法设计与实现
  • NFTScan 正式上线 Starknet NFTScan 浏览器和 NFT API 数据服务
  • 2023年亚太杯APMCM数学建模大赛A题水果采摘机器人的图像识别
  • mysql which is not in SELECT list; this is incompatible with DISTINCT解决方案
  • linux /proc 文件系统
  • java开发之个微群聊自动添加好友
  • Git .gitignore 忽略文件不生效解决方法
  • 【Java】16. HashMap
  • KMP基础架构
  • 递归实现选择排序.
  • Node.js【文件系统模块、路径模块 、连接 MySQL、nodemon、操作 MySQL】(三)-全面详解(学习总结---从入门到深化)
  • 公司的销售经理面临哪些压力和挑战?
  • 【Linux系统编程】如何创建进程(什么是fork函数?进程创建的原理是什么?)
  • 【opencv】计算机视觉基础知识
  • Node——Node.js简介
  • 小型洗衣机什么牌子好又便宜?性价比迷你洗衣机推荐
  • INFINI Easysearch 与华为鲲鹏完成产品兼容互认证
  • 将linux服务器 设置成 proxy.SOCKS5 服务器
  • 无mac电脑生成uniapp云打包私钥证书的攻略
  • py 启动默认浏览器
  • scala可变参数列表使用
  • 经验分享:JMeter控制RPS
  • JavaScript中的for循环你用对了吗?
  • WordPress(10)解决中文连接问题