Night_望 2015-04-10 02:13 采纳率: 0%
浏览 2839

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

  • 写回答

2条回答 默认 最新

  • Night_望 2015-04-13 01:05
    关注

    最后结果是:
    实际上在service里面还有注入的DAO, 而DAO里面包含有数据库连接操作, 由于设置的数据库连接池过小, 导致大量service卡在等待数据库连接上.
    修改数据库连接池后, 恢复正常

    评论

报告相同问题?

悬赏问题

  • ¥15 Qt下使用tcp获取数据的详细操作
  • ¥15 idea右下角设置编码是灰色的
  • ¥15 全志H618ROM新增分区
  • ¥20 jupyter保存图像功能的实现
  • ¥15 在grasshopper里DrawViewportWires更改预览后,禁用电池仍然显示
  • ¥15 NAO机器人的录音程序保存问题
  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键