AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 9110
Accepted
Nik Reiman
Nik Reiman
Asked: 2009-05-18 08:11:33 +0800 CST2009-05-18 08:11:33 +0800 CST 2009-05-18 08:11:33 +0800 CST

一个顽皮的数据库应用程序会导致 Tomcat 崩溃吗?

  • 772

我们有许多通过 Tomcat 运行的 Web 服务,它们使用 hibernate/mysql。我怀疑他们中的一些人没有正确配置连接池,因为几个小时后,一些单独的应用程序会耗尽连接并停止响应。我们一直在对连接池服务(在本例中为 C3P0)进行更改,但我们仍需要将旧版本的应用程序保留在服务器上以实现向后兼容性。

无论如何,我怀疑这些应用程序也在损害 tomcat 的整体稳定性。大约每周一次,我们的服务器完全停止响应,甚至无法提供静态页面。重新启动服务后,一切都会再次运行几天左右。查看日志几乎没有发现任何未捕获的异常,所以我不确定是什么导致 tomcat 崩溃。遗憾的是,在服务器退出响应之前,错误日志中没有列出任何值得注意的东西。

我们也在考虑改用 JBoss,因为它有点“企业化”,但我不相信它会解决这些问题。是否有任何令人信服的理由来切换网络平台,或者我应该在我们自己的网络应用程序中进一步调试?此外,webapp 是否有可能通过做坏事使应用程序服务器崩溃?

服务器配置:Windows 2003 服务器、Tomcat 6.0.18 + blazeDS 3.0、Hibernate 3.2。

tomcat web-applications hibernate
  • 4 4 个回答
  • 2037 Views

4 个回答

  • Voted
  1. Best Answer
    Brian Clozel
    2009-05-18T12:39:02+08:002009-05-18T12:39:02+08:00

    我认为没有人会回答您的问题,而只有线索和想法。这里有一些:

    • 您需要能够检查您服务的每个部分的健康状况的机器人。(测试与数据库的单个连接,获取静态网页,获取动态网页......)。这样,您将看到首先中断或响应时间增加的情况。

    • 你有监控/统计服务吗?您需要跟踪“活动数据库连接数”、“活动 Web 会话数”、“tomcat 线程数”、“可用内存”、CPU ......

    我的建议,没有tomcat进程,因为它们都在等待资源(可能是数据库连接,或者它们只是一个无限循环!)。我之前列出的工具肯定会帮助您了解为什么您的服务器每周都在缓慢死机。

    1. 在您的服务器上运行netstat并查看与数据库服务器的连接数(并根据您的池大小和数据库服务器容量检查它)。
    2. 在您的应用服务器上运行 jstack 并对它们进行剪切/grep/排序以查看您的线程在做什么。
    • 2
  2. Tom Hawtin - tackline
    2009-05-18T12:29:24+08:002009-05-18T12:29:24+08:00

    如果提供静态页面不需要任何数据库访问,那么这似乎不太可能是数据库资源问题。可能是所有池中的线程都卡在某个地方,例如等待数据库驱动器或陷入死锁。我要做的第一件事是使用jstack. visualvm您可以使用或进一步查看该过程jconsole。

    • 1
  3. Rugmonster
    2009-05-18T12:36:26+08:002009-05-18T12:36:26+08:00

    只是想补充一点,MyISAM 表的表锁定问题很常见,这很容易导致数据库连接堆积并导致应用程序等待这些结果坐下。

    您可能想查看 MySQL 进程列表,看看是否有很多查询处于锁定状态。

    # mysqladmin processlist

    - 或者 -

    mysql> show processlist;

    如果锁定是问题所在,您将想看看将问题表上的存储引擎从 MyISAM 更改为 InnoDB 是否可行。

    • 1
  4. Tim Howland
    2009-05-18T17:00:11+08:002009-05-18T17:00:11+08:00

    如果您安装lambda probe webapp(获取 1.7 beta),您可以获得线程级监控;密切关注这一点会告诉您线程何时卡住等待数据库,以及许多其他有用的诊断信息。

    它有点旧,但在最近的 tomcat 版本中仍然可以正常工作。

    • 1

相关问题

  • 谁负责为 Web 应用程序维护 IIS?

  • 如何在家外设置 Web 服务器?[关闭]

  • 外部托管的代理服务器作为内部 HTTP 服务器的前端

  • 阿帕奇的替代品

  • 软件http负载均衡器?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve