db2top工具详解翻译.docx
- 文档编号:23519339
- 上传时间:2023-05-17
- 格式:DOCX
- 页数:13
- 大小:1.15MB
db2top工具详解翻译.docx
《db2top工具详解翻译.docx》由会员分享,可在线阅读,更多相关《db2top工具详解翻译.docx(13页珍藏版)》请在冰豆网上搜索。
db2top工具详解翻译
db2top工具详解(翻译)
Database(d)
Figure2.Databasescreen
在数据库屏幕,db2top提供了一组对整个数据库的性能监控单元。
用户可以监视活动会话(MaxActSess),排序内存(SortMemory)和日志空间(LogUsed)。
这些监测元素可以帮助用户确定这些元素的当前使用百分比。
如果这些因素中的一个开始达到很高甚至100%时,用户应该开始调查发生了什么事。
当前时间和数据库开始时间(StartTime)相比能让我们了解数据库运行了多久。
这个值结合其他检测元素去调查那些已存在一段时间的问题是非常有用的。
锁的使用(LockUsed)和升级(LockEscals)对缩小锁定问题非常有帮助。
如果LockEscals数量很大时,则增加LOCKLIST和MAXLOCKS数据库参数是一个好主意或者寻找那些引起这个问题的不良查询语句。
L_Reads,P_Reads和A_Reads代表逻辑读,物理读和异步读取。
结合的命中率(HitRatio)值,这些变量对于评估大多数的读取发生在存储器中还是磁盘I/O里是非常重要的。
因为磁盘的I/O比存储器存取慢得多,用户更喜欢访问在内存中的数据。
当用户看到HitRatio下降低则可以查看缓冲池(bufferpools)是不是不够大了,或是不是有查询进行了太多的全白扫描而导致页面数据从内存洗冲到磁盘。
和读类似,A_Writes代表异步写入,这表明数据页是由异步页清洁剂之前写的缓冲池空间是必需的。
通过db2top刷新频率这段时间内的写数量我们还能知道有多少写请求发生了。
还能计算每次写入的平均花费时间这对分析I/O瓶颈引起的一些性能问题有所帮助。
当A_Writes/Writes的比值越高则写I/O性能越高。
SortOvf代表排序溢出。
如果用户发现这个数字变为非常高,就需要寻找查询了。
排序溢出发生在SORTHEAP不足够大,导致排序(Sort)或HashJoin操作可能会溢出数据到临时空间。
有时该值随着SORTHEAP增加而降低,但在其他情况下,可能没有多大帮助,如果进行排序的数据集比可分配给SORTHEAP内存大得多。
如果请求的数据量超过缓冲池可容纳的临时空间大小那么就可能需要物理I/O来进行SORT或哈希链接在这种情况下排序溢出将是很大的瓶颈。
因此优化查询来减少排序溢出的数量能显着提高系统的性能。
在数据库屏幕的最后四个条目显示的平均物理读取时间(AvgPRdTime),平均直接读取时间(AvgDRdTime),物理平均写入时间(AvgPWrTime)和平均直接写入时间(AvgDWrTime)。
这四个项目直接反映I/O子系统性能。
如果用户发现一个意想不到的大量的时间花费在每个读或写操作,进一步的调查应到I/O子系统。
正常情况下,DB2排序发生在内存中,这块内存叫做排序堆,即SORTHEAP。
当需要排序的数据超出SORTHEAP大小限制时,就会发生排序溢出。
溢出的数据会写到临时表中,这会产生更多的I/O,因此对性能会有较大影响。
Tablespace(t)
Figure3.Tablespacescreen
表空间屏幕提供每个表空间的详细信息。
HitRatio%和AsyncReads%列对用户来说是非常重要的。
在数据库级别仅仅监视缓冲池命中率,你可能无法获得足够精确的信息。
在包含多个表空间的环境中,在一个表空间中发生了不良查询现象会被所有表空间平均命中率遮蔽。
在每个表空间级别上监测HitRatio%和AsyncReads%对于分析系统工作细节很有帮助。
Delta逻辑读取(写)和Delta物理读取(写)(Delta逻辑读(写入)和Delta物理读(写入))说明这些表空间如何“忙”的。
一些不太活跃的表空间可能不具有非常高的缓冲命中率。
在大多数情况下最好使用活动性更大的表空间。
想要左右滚动屏幕可以使用键盘上的左,右箭头键。
所有的列信息不能在一个屏幕上显示可以通过按下左或右箭头键来查看。
SpaceUsed,TotalSize和%full能够很方便的查看各表空间的使用率情况,还能从其他列信息中查看表空间类型是DMS还是SMS。
DynamicSQL(D)
Figure4.DynamicSQLscreen
动态SQL屏幕提供缓存的SQL语句的详细信息。
用户可以再此屏幕对特定SQL语句产生执行计划(DB2EXPLN)和(db2exfmt)。
执行数量(NumExecution)和平均执行时间(AvgExecTime)可以用来了解查询语句执行了多少次和平均运行时间。
通过平均CPU时间(AvgCpuTime)与平均执行时间(AvgExecTime)比较能看出执行时间花费在CPU上还是花在了等待锁或I/O上。
行读取(Rowread)和行写入(Rowwritten)能够明白查询的行为。
例如,如果用户看到一个SELECT查询语句关联了大量的写,这可能表明该查询可能会有排序(哈希联接)溢出而且需要进一步调整来以避免数据溢出临时空间。
数据,索引的Hitratio(命中率%)和临时l_reads来帮助用户轻松解决缓冲池大小是否需要调整。
(AvgSortPerExec)和排序时间能计算出在一次执行期间进行了多少排序。
db2top实用程序还提供了产生DB2EXPLN或db2exfmt报告功能而无需手动运行该命令。
通过动态SQL屏幕上输入一个大写L,它会提示你输入一个SQL字符串哈希。
SQL散列字符串位于表中的第一列,例如“00000005429283.”用户可以复制该字符串并将其粘贴到光标提示处,按下Enter键,如图5:
Figure5.DynamicSQLscreen--Querytext
然后,选择e选项生成DB2EXPLN输出,或者选择x选项生成db2exfmt输出如果已经导入到数据库中。
Session(l)
Figure6.Sessionscreen
会话屏幕提供每个应用程序会话的详细信息。
第一列显示了应用句柄,下面三列:
CPU%总计,IO%总计,MEM%总计表示本应用消耗资源的百分比。
在大多数情况下,每个会话表示一个连接。
在这些列之后还显示了应用状态,以及一些统计数据读写的列。
用户还可以看到LocksHeld,Sort(sec),LogUsed信息在此屏幕上。
当事务日志耗尽空间时LogUsed信息就很有帮助了。
通过使用这种显示器的个监控元素,用户可以得到一些想法那些应用程序消耗大部分日志空间。
虽然会话屏幕上的信息和数据库屏幕上的信息差不多,但是会话屏幕上的信息为每个应用程序的。
做性能分析要结合不同的屏幕。
例如,当一些读问题显示在数据库屏幕上时可以进一步通过查看会话屏和动态SQL画面上以缩小它的特定应用程序或SQL。
在session屏幕按i查找哪些正在等待Lock的应用
Bufferpool(b)
Figure7.Bufferpoolscreen
在此屏幕上,db2top提供了每个缓冲池的信息。
用户可以看到的一些缓冲池的基本信息,如读,写,和大小,还可以看到其他信息,如缓冲池命中率%和异步读取%率。
Lock(U)
Figure8.Lockscreen
一个锁定的问题是应用程序诊断中最常见的问题之一。
通过db2top,用户可以很容易地列出了应用程序持有的锁。
使用db2top也更容易分析锁等待的问题。
下面图9,10和11显示其中一个db2bp应用程序正在等待另一db2bp会话。
Figure9.Lockwaiting--Applicationstatus
在图9中,两代理(代理24和代理9)处于第一列:
AgentId(state)。
你可以看到,在第三列(应用状态)其中一个代理(代理24)被卡在锁等待状态。
Figure10.Lockwaiting--Lockstatus
如果用户希望看到更多信息,请按键盘上的左箭头,如图10。
Figure11.Lockwaiting--Tablename
在这个特殊的例子中,如图11看到的那样,代理24试图去请求表上的S锁,但是它被拥有T1表IX锁的代理9锁定。
db2to在此屏幕提供了另一个非常有用的功能:
锁链分析。
并不总是容易弄清楚锁等待的关系,如果有多个应用程序涉及。
db2top实用程序提供了一个有用的特性来动态绘制锁链,使其更容易为用户了解应用程序之间的锁定关系。
通过输入大写L,显示锁链。
就像图12显示的这样:
Figure12.Lockwaiting--Lockchain
Table(T)
Figure13.Tablescreen
表屏幕显示数据库中的表的信息。
一段时间中没有访问的表显示为白色。
正在存取(活跃)表显示绿色。
有关于表本身的信息。
列中的数据页(Datapages)和索引页(Indexpages)代表多少页在表中。
表类型和表大小也是表的很重要的属性。
另一个重要的列是行溢出/秒(RowsOverflows/s),这表明每秒行溢出的数量。
溢出的行表明发生数据碎片。
如果这个数字很高,用户应该使用REORG实用程序,清理这种碎片重组表提高表的性能。
Bottlenecks(B)
Figure14.Bottlenecks
瓶颈分析对于一个DBA来说是不能忽视。
他们想知道哪个代理(应用)严重地限制了整个系统的性能。
标题“瓶颈”右下角的方框是关于各种数据库操作的时序分析:
Theelapsedtimeusedtocalculatethepercentageofeachoperation=(wait_lock_time+sort_time+bp_read_time+bp_write_time+async_read_time+async_write_time+prefetch_waite_time+direct_read_time+direct_write_time).
以下为每个操作所估计的百分比:
waitlockms:
(waitlocktime)/(elapsedtime)=80%
sortms:
(sorttime)/(elapsedtime)=0
bpr/wms:
(bufferpoolreadandwritetime)/(elapsedtime)=10%
asyncr/wms:
(asyncreadandwrite)/(elapsedtime)=6%
prefwaitms:
(prefetch_waite_time)/(elapsedtime)=2%
dirr/wms:
(directreadandwritetime)/(elapsedtime)=2%
这个屏幕的主要显示部分为对于每一种系统资源哪个agent(应用)占用最大
屏幕上显示的服务器资源显示db2top所监控的服务器资源:
Cpu:
WhichagentconsumesthemostCPUtime.
SessionCpu:
WhichapplicationsessionconsumesthemostCPUtime.
IOr/w:
WhichagentconsumesthemostI/Oreadandwrite.
Memory:
Whichagentconsumesthemostmemory.
Lock:
Whichagentisholdingthemostlocks.
Sorts:
Whichagenthasexecutedthebiggestnumberofsorting.
SortTimes:
Whichagentconsumesthelongestsortingtime.
LogUsed:
Whichagentconsumesthemostlogspaceinthemostrecentunitofwork.
Overflows:
Whichagenthasthemostnumberofsortoverflows.
RowsRead:
Whichagenthasreadthemostnumberofrowsofrecords.
RowsWritten:
Whichagenthaswrittenthemostnumberofrowsofrecords.
TQr/w:
Whichagenthassentandreceivedmostnumberofrowsontablequeues.
MaxQueryCost:
WhichagenthasthemaxSQLexecutiontimeestimatedbythecompiler.
XDAPages:
WhichagenthasthemostnumberofpagesforXDAdata(availableinandafterreleases).
例如:
图14示出了代理683表明db2bp(DB2backendprocess)是很明显的瓶颈。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- db2top 工具 详解 翻译