【问题标题】:How to improve performance of application using DB queries? [closed]如何使用 DB 查询提高应用程序的性能? [关闭]
【发布时间】:2013-02-18 12:16:28
【问题描述】:

我是一名数据库人员,我有一个基于 Java 的 Web 应用程序。

它运行缓慢,开发人员向我报告说,仅由于 DB,它运行缓慢。他们要求进行查询调优。

我尝试调整查询,但无法获得太多性能。

当我尝试在浏览器中运行查询时,它工作正常,但在应用程序中却很慢。

请给我一些关于如何解决这个问题的建议。

【问题讨论】:

  • 您应该考虑询问具体的问题/问题,并提供一些细节以了解问题。笼统的工作特定问题不会让您对 SO 做出回应。
  • 我不知道他们只是将问题归咎于查询。
  • “请给我建议” - 分析应用程序,或让开发人员去做。
  • 如果他们指责查询,让他们向您展示证据。分析器将准确显示应用程序的哪个部分花费了多少时间。

标签: java mysql database performance


【解决方案1】:

以下是我的处理方法:

  • 让开发人员选择一个运行缓慢的用例,然后让他们向您描述。他们还应该提及作为该用例的一部分运行的所有查询,包括参数。
  • 当您从 SQL 工具而不是应用程序直接针对数据库运行查询结果时,向他们显示查询结果。确保使用相同的数据库实例和相同的数据量。
  • 如果时间相差很大,请让开发人员使用 Java 分析器(例如 YourKit 或 visualVM)来确定时间花在了哪里。这应该可以很容易地发现瓶颈。
  • 当应用程序运行缓慢时,请注意上下文。是针对单个用户,还是针对多个用户执行相同的用例?
  • 大多数数据库也会写入日志文件,概述查询性能并突出显示有问题的查询。 Oracle 的 AWR 文件就是一个例子,也许 MySQL 也有类似的东西。

基本上,尝试与开发人员合作,而不是反对他们。向他们解释您是如何调整查询的,并让他们向您展示他们如何尝试调整应用程序。这种方法一直对我有用。

【讨论】:

  • 感谢您的简短解释。
猜你喜欢
  • 1970-01-01
  • 2012-03-03
  • 2021-11-24
  • 1970-01-01
  • 1970-01-01
  • 2012-01-28
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多