gpt4 book ai didi

performance - Web 应用程序在 Tomcat 7 中非常慢

转载 作者:行者123 更新时间:2023-11-28 21:45:21 25 4
gpt4 key购买 nike

我实现了一个 Web 应用程序来启动 Tomcat 服务工作得非常快,但是花费数小时并且当更多用户输入时速度变慢(大约最多 15 个用户)。

检查 RAM 使用统计数据 (20%)、CPU (25%)

服务器特性:

  • 内存 8GB
  • i7 处理器
  • window 服务器 2008 64 位
  • Tomcat 7
  • MySql 5.0
  • Struts2
  • -Xms1024m
  • -Xmx1024m
  • 永久代 = 1024
  • MaxPernGen = 1024

我不使用Web服务器,我们直接在Tomcat上发布。

进入午夜慢度依旧维持(只有1人在线)

我的解决方案是重新启动 Tomcat 服务,响应时间再次出色。

有没有人遇到过这个问题?任何线索将不胜感激。

最佳答案

没有提供足够的细节。需要更多信息:(

使用 htoptop 查找每个进程和每个线程的内存和 CPU 使用情况。

中央处理器

4 核系统中 CPU 使用率恒定为 25% 表明单核应用程序/线程在它能够使用的唯一内核上运行 100% CPU。

哪个应用程序正在占用 CPU?

内存

20% 的内存约为 1.6GB。对于仅运行 tomcat + mysql 的闲置服务器,这比我预期的要多一些。 -Xms1024 告诉 tomcat 预分配 1GB 内存以便解释它。

将 tomcat 设置更改为 -Xms512-Xmx2048。观察 tomcat 内存使用情况,同时让一些用户使用它。如果它一直增长直到达到 2GB...然后卡住,这可能表明存在内存泄漏。

磁盘

使用 df -h 检查磁盘使用情况。完整的分区可能会导致您遇到的问题。

Filesystem    Size  Used Avail Usage% Mounted on
/cygdrive/c 149G 149G 414M 100% /

(如果您刚刚在此示例中发现我的笔记本电脑空间不足。您做对了:D)

日志

日志很棒。然而他们有一个坏习惯,就是把磁盘填满。检查日志磁盘使用情况。新用户连接时日志是否被正确写入/删除/轮换?删除日志是否可以解决问题? (在删除它们之前将它们复制到某处以供将来分析)

如果没有。日志仍然很棒。他们有帮助您跟踪错误的好习惯。检查tomcat日志。您可能希望将日志记录级别设置为调试。当网站死亡时最后会发生什么?任何有用的错误信息? tomcat 是否仍接收并接受用户连接?

申请

我假设 25% 的 CPU 分配给了 tomcat(而不是 mysql)。 Tomcat 本身不会失败。在其上运行的应用程序必须失败。尝试从 tomcat 中删除该应用程序(您最终可以放置一个 hello world)。 tomcat 可以在没有您的应用程序的情况下保持通宵工作吗?它可能可以,在这种情况下,故障出在应用程序上。

在您的应用程序中启用完整的调试日志记录并尝试跟踪问题。在 Debug模式下直接从 eclipse 运行它并向用户抛出问题。它是否以同样的方式持续失败?

如果是,请在 eclipse 调试器中点击“暂停”并检查应用程序正在做什么。查看每个线程当前正在运行的代码及其调用堆栈。重复几次。如果存在死锁、无限循环或类似情况,您可以通过这种方式找到它。

如果幸运的话,您现在应该已经找到问题所在了。如果不是,那你很不幸,这是一个可能深藏在应用程序内部的棘手错误。这可能很难追踪。决心会导致成功。祝你好运 =)

关于performance - Web 应用程序在 Tomcat 7 中非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12410951/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com