51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1697|回复: 0
打印 上一主题 下一主题

《性能测试进阶指南Loadrunner+9.1实战》笔记——数据库性能问题

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2018-5-21 16:17:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
应用数据库三大类典型性能问题分析如下:

  1、过量数据库调用

       问题:常见的性能瓶颈来自过量的数据库调用,引发这些问题不一定是SQL查询的Execute()/Update
(),而是应用程序与数据库的交互,例如ResultSet操作,常见的问题是指定了过于精细的查询条件,然后
使用ResultSet.Next()详细搜索返回的数据。

       解决办法:从数据库中大量取得所要求的数据,避免应用程序反复回调数据库。

  2、数据库连接池问题

      问题1:连接池资源泄露,虽然可以通过WebLogic自带工具检测到数据库连接池资源泄露,但是很难
在应用程序代码本身准确定位泄露的源头。

      解决办法:分析程序代码,是否没有close()连接?是否遗漏了finally块?或者尽管有close()但是并没有
成功?

      问题2:连接池大小,连接池过小导致连接池满后,新客户无法连接上系统,在日志中出现错误信息。
解决方法是增大连接池,但是连接池过的会造成资源无效耗损,可能会出现新的性能问题,那么连接池
多大比较合适呢?

      解决办法:经验法则1:数据库连接池数=线程池数*每个线程需要连接数据库的平均数*1.1

                    经验法则2:设置最初池大小=最大池大小

   3、SQL语句及其索引或锁定属性问题

      问题:SQL语句及其索引或锁定属性不合理可能引发磁盘读写数据过忙,或者CPU过忙,造成执行时
间过长,阻塞线程的执行,最终引发系统挂起或者执行超时引发系统挂起。

      解决办法:优化SQL语句及其索引或锁定属性。

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-26 23:06 , Processed in 0.062973 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表