问题描述
- Spring mvc架构在并发情形下性能急剧下降的问题
-
在公司有一个基于spring-mvc框架的web项目, 在100个用户同时访问的情况下响应时间超过10秒.
经过排查, 发现在Controller中调用所有注入的service方法, 均需要超过2秒的时间.
后来干脆把service里的代码先注释掉, 在Controller中调用空的service方法, 依然需要超过2秒.
service都是多实例的, 设置了singleton="false"
目前没有头绪...特来向大家求助, 感激不尽!例如:
测时间用的如下方式long beginVerify = System.currentTimeMillis(); int status = userService.verifySSOUser(); long costVerify = System.currentTimeMillis() - beginVerify; System.out.println("verifySSOUser()用时: "+costVerify+"ms");
verifySSOUser()内部代码全部注释掉了, 只留有return 1;
最后输出时显示:
10个并发情况下, 用时小于10ms
100个并发情况下, 用时接近3s
200个并发情况下, 用时接近10s
解决方案
最后结果是:
实际上在service里面还有注入的DAO, 而DAO里面包含有数据库连接操作, 由于设置的数据库连接池过小, 导致大量service卡在等待数据库连接上.
修改数据库连接池后, 恢复正常
解决方案二:
看你的问题,我也学习了!CSDN看技术问答一个好处:看别人的错误,也能积累自己的知识。
时间: 2024-10-28 12:03:10