用 db2pd 工具分析 DB2 for Linux,UNIX,and Windows 中锁的等待并发问题原因
来源:互联网 发布:王者荣耀fps优化工具 编辑:程序博客网 时间:2024/06/05 15:53
当多个 DB2® 用户并发地访问一个数据库时,锁等待会导致响应变慢。锁等待是临时性的,因而难以捕捉。然而,当出现锁等待情形时,需要由数据库管理员负责确定锁等待的原因。本文通过例子演示如何使用用于 DB2 for Linux®, UNIX®, and Windows® 的db2pd
和db2pdcfg
实用程序完成该任务。
用于锁监视的 db2pd
选项
db2pd
是用于监视各种 DB2 数据库活动以及故障排除的实用程序。它是从 DB2 V8.2 开始随 DB2 引擎发布的一个独立的实用程序,其外观和功能类似于 Informix onstat
实用程序。db2pd
是从命令行以一种可选的交互模式执行的。该实用程序运行得非常快,因为它不需要获取任何锁,并且在引擎资源以外运行(这意味着它甚至能在一个挂起的引擎上工作)。通过快照监视还可以收集 db2pd
提供的很多监视器数据,但是 db2pd
和快照监视的输出格式却有很大不同。这使 DBA 可以选择更符合用户需求的监视替代方法。本文关注用于锁监视的 db2pd
选项。有一篇由 Sam Poon 撰写的 developerWorks 文章(参见 参考资料 小节)对 db2pd
的监视功能作了更广泛的介绍。
下面的图展示了用于锁监视的 db2pd
选项:
图 1. 用于锁监视的
db2pd
选项TranHdl
:用于指定事务句柄,以便只监视由特定事务持有的锁。showlocks
:这个子选项将锁名称扩展成有意义的解释。对于一个行锁,该选项显示以下信息:表空间 ID、表 ID、分区 ID、页和槽。通过使用编目视图SYSCAT.TABLES
上的一个查询,很容易将表空间 ID 和表 ID 映射到相应的表名:
清单 1. 将表空间 ID、表 ID 映射到表模式、表名
SELECT TABSCHEMA, TABNAME
FROM SYSCAT.TABLES
WHERE TBSPACEID = tbspaceid AND TABLEID = tableid
wait
:如果指定wait
子选项,则db2pd
只显示事务当前正在等待的锁,以及对等待情形负责的锁。这个子选项大大简化了锁等待分析,因为它将输出限制为参与锁等待情形的锁。db2pd database
和file
选项不是特定于锁监视的,但是适用于(几乎)所有db2pd
调用。database
选项将db2pd
返回的监视器数据限制为某个数据库的监视器数据。而file
选项则允许定义一个文件,以便将db2pd
输出写到该文件。
锁等待分析场景
接下来,我们开始使用前面介绍的 db2pd
选项来分析一个示例锁等待情形。为此,我们创建 DB2 SAMPLE
数据库:
清单 2. 创建
SAMPLE
数据库
db2sampl
用户 A 执行事务 A,以根据每个经理的薪水为他们提供 10% 的奖金:
清单 3. 事务 A 执行的更新操作
UPDATE EMPLOYEE
SET BONUS = SALARY * 0.1
WHERE JOB = 'MANAGER'
当事务 A 仍然在运行(因为用户 A 还没有使用 COMMIT
或 ROLLBACK
终止该事务)时,用户 B 执行事务 B,以将每个雇员的薪水提高 2%:
清单 4. 事务 B 执行的更新操作
UPDATE EMPLOYEE
SET SALARY = SALARY * 0.02
由于事务 B 没有完成,用户 B 请求 DBA 确定问题的原因。于是,DBA 调用 db2pd
,看是否存在锁等待情形:
清单 5. 检查锁等待情形
db2pd -db sample -locks wait showlocks
Database Partition 0 -- Database SAMPLE -- Active -- Up 3 days 08:33:05
Locks:
Address TranHdl Lockname Type Mode Sts Owner Dur
0x050A0240 6 02000600050040010000000052 Row ..X W 2 1
0x050A0DB0 2 02000600050040010000000052 Row ..X G 2 1
HoldCount Att ReleaseFlg
0 0x00 0x40000000 TbspaceID 2 TableID 6 PartitionID 0 Page 320 Slot 5
0 0x00 0x40000000 TbspaceID 2 TableID 6 PartitionID 0 Page 320 Slot 5
db2pd
报告 ID 为 2 的表空间中一个 ID 为 6 的表上有一个行锁存在锁等待情形。通过检查 SYSCAT.TABLES
,DBA 断定表 EMPLOYEE
上的确存在锁等待。
清单 6. 确定锁等待情形所涉及的表
本文转自IBM Developerworks中国
请点击此处查看全文
- 用 db2pd 工具分析 DB2 for Linux,UNIX,and Windows 中锁的等待并发问题原因
- db2pd 分析锁等待 步骤 --【监控】
- DB2 UDB v8 Handbook for Windows and UNIX/Linux
- DB29 for Linux,UNIX,and WINDOWS - section 4(DB2 Security)
- DB29 for Linux,UNIX,and WINDOWS - section 5(DB2 Object)
- DB29 for Linux,UNIX,and WINDOWS - section 6(DB2 SQL)
- DB29 for Linux,UNIX,and WINDOWS - section 9(DB2 Concurrent)
- DB29 for Linux,UNIX,and WINDOWS - section 11(DB2 storage)
- DB29 for Linux,UNIX,and WINDOWS - section 13(DB2 performance)
- 一种经济有效的使用值压缩 DB2 for Linux,UNIX,and Windows 数据库
- DB2 9 for Linux, UNIX, and Windows: DBA Guide, Reference, and Exam Prep (6th Edition)
- 利用 Oracle 10g 技能学习 DB2 9.1 for Linux, UNIX and Windows
- 利用 Oracle 10g 技能学习 DB2 9.1 for Linux, UNIX and Windows
- 利用 Oracle 10g 技能学习 DB2 9.1 for Linux, UNIX and Windows
- Recommended reading list: DB2 for Linux, UNIX, and Windows database administration
- 为 IBM DB2 for Linux、UNIX and Windows 以及 IBM Content Manager 编写自动安装脚本
- 利用 Oracle 10g 技能学习 DB2 9.1 for Linux, UNIX and Windows
- DB29 for Linux,UNIX,and WINDOWS - section 1(DB2 product family)
- 自己是个雏鸟····
- 哈佛图书馆上的训言!
- 应该记住的flex开发快捷键
- 学习java的30个目标
- 2014年全球SOA市场规模将达91亿美元
- 用 db2pd 工具分析 DB2 for Linux,UNIX,and Windows 中锁的等待并发问题原因
- Linux下mysql基本操作小结
- apache手册
- 对HTTP协议的头信息详解
- Linux下基于Jrtplib库的实时传送实现 [转]
- HTTP协议,简单总结一下
- MySQL时间函数
- js中对象转到c#对象方法
- 领导沉稳性格如何磨砺