分析DB2 9.5中的锁定超时原因

数据库
在 DB29.5数据库中,分析锁定超时的方法得到了相当大的改进,锁定超时分析也变得十分简单。本文探索这些全新的锁定超时报告功能,并检查收集的附加信息以确定发生锁定超时的原因。

DB29.5中,分析锁定超时的方法得到了极大改进,锁定超时分析变得更加简单。本文主要是探索这些全新的锁定超时报告功能,并检查收集的附加信息以确定发生锁定超时的具体原因。

 

回顾DB2 9.1中的锁定超时分析

使用db2pd工具和db2cos脚本进行锁定超时分析的方法包含以下几步:

1.使用一个特殊的DB2脚本 — 名为 db2cos — 在每次调用db2cos脚本时执行一个db2pd调用。db2pd 调用收集与锁定、事务、应用程序、语句缓存相关的信息,并将信息存储在一个文本文件中以供分析。

2.要在锁定超时发生时自动执行 db2cos 脚本(以及包含的 db2pd 命令,需要使用 db2pdcfg 命令注册锁定超时事件。

3.在锁定超时事件中,DBA 可以检查通过自动调用 db2cos 脚本生成的 db2pd 输出。这使 DBA 能够确定发生锁定争用的原因,从而设法在以后避免发生这类情形。

尽管其中介绍的方法提供了大量信息,使得锁定超时分析比以前的 DB2 9 for Linux, Unix, and Windows 版本更加简单,但它仍然存在一些不足:

◆使用此方法需要手动改写 db2cos 脚本并通过调用 db2pdcfg 来注册锁定超时事件。两个步骤都不复杂,但是对于新手来说可能有些困难。

◆解释 db2pd 输出以识别锁定超时情形中涉及的应用程序和 SQL 语句,这个任务并不容易,而且需要一些尝试。

◆如果锁定超时是由包含多个 SQL 命令的事务引起的,那么 db2pd 收集的信息可能还不足以确定导致锁定的 SQL 语句。

DB2 9.5 中全新的锁定超时报告功能

在 DB2 9.5 的锁定超时报告功能中,引入了一个新特性,使得锁定超时分析变得非常简单。要激活锁定超时报告,只需将 DB2 注册变量 DB2_CAPTURE_LOCKTIMEOUT 设置为 ON,并重新启动您的 DB2 实例:

清单 1. 激活 DB2 9.5 中的锁定超时报告

  1. db2set DB2_CAPTURE_LOCKTIMEOUT=ON   
  2. db2stop   
  3. db2start  

是的,就是这么简单。当 DB2_CAPTURE_LOCKTIMEOUT 设置为 ON 时,DB2 为每个锁定超时事件自动创建一个报告文件。报告文件保存在 DIAGPATH 数据库管理员配置(DBM CFG)参数指向的目录中,包含的信息有:锁定超时的日期和时间、存在问题的锁定、锁定请求程序和锁定拥有者。

 

那么 DB2 9.5 中就不使用 db2cos 脚本了吗?事实并非如此。将 db2cos 脚本和 db2pd 工具结合具有非常广泛的用途。这意味着,这些工具组合仍然可用于捕捉与 SQL 代码和 DB2 内部返回代码相关的任何 DB2 事件信息,而不仅仅是锁定超时信息。

现在看看新的 DB2 9.5 注册变量 DB2_CAPTURE_LOCKTIMEOUT 并查看一个使用 DB2 SAMPLE 数据库的锁定超时示例场景。如果 SAMPLE 数据库不存在,可以调用下面的命令创建一个:

分析DB2 9.5中的锁定超时原因

作者: kaduo,  出处:IT专家网论坛, 责任编辑: 陈子琪, 2009-05-20 07:00

 

在 DB29.5中,分析锁定超时的方法得到了极大改进,锁定超时分析变得更加简单。本文探索这些全新的锁定超时报告功能,并检查收集的附加信息以确定发生锁定超时的原因。

 

在 DB29.5中,分析锁定超时的方法得到了极大改进,锁定超时分析变得更加简单。本文探索这些全新的锁定超时报告功能,并检查收集的附加信息以确定发生锁定超时的原因。

 

回顾DB2 9.1中的锁定超时分析

使用db2pd工具和db2cos脚本进行锁定超时分析的方法包含以下几步:

1.使用一个特殊的DB2脚本 — 名为 db2cos — 在每次调用db2cos脚本时执行一个db2pd调用。db2pd 调用收集与锁定、事务、应用程序、语句缓存相关的信息,并将信息存储在一个文本文件中以供分析。

2.要在锁定超时发生时自动执行 db2cos 脚本(以及包含的 db2pd 命令,需要使用 db2pdcfg 命令注册锁定超时事件。

3.在锁定超时事件中,DBA 可以检查通过自动调用 db2cos 脚本生成的 db2pd 输出。这使 DBA 能够确定发生锁定争用的原因,从而设法在以后避免发生这类情形。

尽管其中介绍的方法提供了大量信息,使得锁定超时分析比以前的 DB2 9 for Linux, Unix, and Windows 版本更加简单,但它仍然存在一些不足:

◆使用此方法需要手动改写 db2cos 脚本并通过调用 db2pdcfg 来注册锁定超时事件。两个步骤都不复杂,但是对于新手来说可能有些困难。

◆解释 db2pd 输出以识别锁定超时情形中涉及的应用程序和 SQL 语句,这个任务并不容易,而且需要一些尝试。

◆如果锁定超时是由包含多个 SQL 命令的事务引起的,那么 db2pd 收集的信息可能还不足以确定导致锁定的 SQL 语句。

DB2 9.5 中全新的锁定超时报告功能

在 DB2 9.5 的锁定超时报告功能中,引入了一个新特性,使得锁定超时分析变得非常简单。要激活锁定超时报告,只需将 DB2 注册变量 DB2_CAPTURE_LOCKTIMEOUT 设置为 ON,并重新启动您的 DB2 实例:

清单 1. 激活 DB2 9.5 中的锁定超时报告

  1. db2set DB2_CAPTURE_LOCKTIMEOUT=ON   
  2. db2stop   
  3. db2start  

是的,就是这么简单。当 DB2_CAPTURE_LOCKTIMEOUT 设置为 ON 时,DB2 为每个锁定超时事件自动创建一个报告文件。报告文件保存在 DIAGPATH 数据库管理员配置(DBM CFG)参数指向的目录中,包含的信息有:锁定超时的日期和时间、存在问题的锁定、锁定请求程序和锁定拥有者。

 

那么 DB2 9.5 中就不使用 db2cos 脚本了吗?事实并非如此。将 db2cos 脚本和 db2pd 工具结合具有非常广泛的用途。这意味着,这些工具组合仍然可用于捕捉与 SQL 代码和 DB2 内部返回代码相关的任何 DB2 事件信息,而不仅仅是锁定超时信息。

现在看看新的 DB2 9.5 注册变量 DB2_CAPTURE_LOCKTIMEOUT 并查看一个使用 DB2 SAMPLE 数据库的锁定超时示例场景。如果 SAMPLE 数据库不存在,可以调用下面的命令创建一个:#p#

清单6. 锁定超时报告

  1. LOCK TIMEOUT REPORT   
  2. Date: 03/01/2008   
  3. Time: 07:34:31   
  4. Instance: DB2   
  5. Database: SAMPLE   
  6. Database Partition: 0   
  7. Lock Information:   
  8. Lock Name: 02000600040040010000000052   
  9. Lock Type: Row   
  10. Lock Specifics: Tablespace ID=2, Table ID=6, Row ID=x0400400100000000   
  11. Lock Requestor:   
  12. System Auth ID: FECHNER   
  13. Application Handle: [0-38]   
  14. Application ID: *LOCAL.DB2.080103063343   
  15. Application Name: db2bp.exe   
  16. Requesting Agent ID: 5232   
  17. Coordinator Agent ID: 5232   
  18. Coordinator Partition: 0   
  19. Lock timeout Value: 10000 milliseconds   
  20. Lock mode requested: ..U   
  21. Application Status: (SQLM_UOWEXEC)   
  22. Current Operation: (SQLM_EXECUTE_IMMEDIATE)   
  23. Lock Escalation: No   
  24. Context of Lock Request:   
  25. Identification: UOW ID (1); Activity ID (1)   
  26. Activity Information:   
  27. Package Schema: (NULLID )   
  28. Package Name: (SQLC2G13NULLID )   
  29. Package Version: ()   
  30. Section Entry Number: 203   
  31. SQL Type: Dynamic   
  32. Statement Type: DML, Insert/Update/Delete   
  33. Effective Isolation: Cursor Stability   
  34. Statement Unicode Flag: No   
  35. Statement: UPDATE EMPLOYEE SET BONUS = SALARY * 0.1   
  36. WHERE JOB = 'MANAGER'   
  37. Lock Owner (Representative):   
  38. System Auth ID: FECHNER   
  39. Application Handle: [0-33]   
  40. Application ID: *LOCAL.DB2.080103063332   
  41. Application Name: db2bp.exe   
  42. Requesting Agent ID: 5488   
  43. Coordinator Agent ID: 5488   
  44. Coordinator Partition: 0   
  45. Lock mode held: ..X   
  46. List of Active SQL Statements: Not available   
  47. List of Inactive SQL Statements from current UOW: Not available  

清单6. 锁定超时报告

  1. LOCK TIMEOUT REPORT   
  2. Date: 03/01/2008   
  3. Time: 07:34:31   
  4. Instance: DB2   
  5. Database: SAMPLE   
  6. Database Partition: 0   
  7. Lock Information:   
  8. Lock Name: 02000600040040010000000052   
  9. Lock Type: Row   
  10. Lock Specifics: Tablespace ID=2, Table ID=6, Row ID=x0400400100000000   
  11. Lock Requestor:   
  12. System Auth ID: FECHNER   
  13. Application Handle: [0-38]   
  14. Application ID: *LOCAL.DB2.080103063343   
  15. Application Name: db2bp.exe   
  16. Requesting Agent ID: 5232   
  17. Coordinator Agent ID: 5232   
  18. Coordinator Partition: 0   
  19. Lock timeout Value: 10000 milliseconds   
  20. Lock mode requested: ..U   
  21. Application Status: (SQLM_UOWEXEC)   
  22. Current Operation: (SQLM_EXECUTE_IMMEDIATE)   
  23. Lock Escalation: No   
  24. Context of Lock Request:   
  25. Identification: UOW ID (1); Activity ID (1)   
  26. Activity Information:   
  27. Package Schema: (NULLID )   
  28. Package Name: (SQLC2G13NULLID )   
  29. Package Version: ()   
  30. Section Entry Number: 203   
  31. SQL Type: Dynamic   
  32. Statement Type: DML, Insert/Update/Delete   
  33. Effective Isolation: Cursor Stability   
  34. Statement Unicode Flag: No   
  35. Statement: UPDATE EMPLOYEE SET BONUS = SALARY * 0.1   
  36. WHERE JOB = 'MANAGER'   
  37. Lock Owner (Representative):   
  38. System Auth ID: FECHNER   
  39. Application Handle: [0-33]   
  40. Application ID: *LOCAL.DB2.080103063332   
  41. Application Name: db2bp.exe   
  42. Requesting Agent ID: 5488   
  43. Coordinator Agent ID: 5488   
  44. Coordinator Partition: 0   
  45. Lock mode held: ..X   
  46. List of Active SQL Statements: Not available   
  47. List of Inactive SQL Statements from current UOW: Not available  

 清单9. 包含 SQL 语句历史信息的锁定超时报告

  1. LOCK TIMEOUT REPORT   
  2. Date: 03/01/2008   
  3. Time: 15:10:13   
  4. Instance: DB2   
  5. Database: SAMPLE   
  6. Database Partition: 0   
  7. Lock Information:   
  8. Lock Name: 02000600040040010000000052   
  9. Lock Type: Row   
  10. Lock Specifics: Tablespace ID=2, Table ID=6, Row ID=x0400400100000000   
  11. Lock Requestor:   
  12. System Auth ID: FECHNER   
  13. Application Handle: [0-202]   
  14. Application ID: *LOCAL.DB2.080103140934   
  15. Application Name: db2bp.exe   
  16. Requesting Agent ID: 2356   
  17. Coordinator Agent ID: 2356   
  18. Coordinator Partition: 0   
  19. Lock timeout Value: 10000 milliseconds   
  20. Lock mode requested: ..U   
  21. Application Status: (SQLM_UOWEXEC)   
  22. Current Operation: (SQLM_EXECUTE_IMMEDIATE)   
  23. Lock Escalation: No   
  24. Context of Lock Request:   
  25. Identification: UOW ID (1); Activity ID (1)   
  26. Activity Information:   
  27. Package Schema: (NULLID )   
  28. Package Name: (SQLC2G13NULLID )   
  29. Package Version: ()   
  30. Section Entry Number: 203   
  31. SQL Type: Dynamic   
  32. Statement Type: DML, Insert/Update/Delete   
  33. Effective Isolation: Cursor Stability   
  34. Statement Unicode Flag: No   
  35. Statement: UPDATE EMPLOYEE SET BONUS = SALARY * 0.1   
  36. WHERE JOB = 'MANAGER'   
  37. Lock Owner (Representative):   
  38. System Auth ID: FECHNER   
  39. Application Handle: [0-188]   
  40. Application ID: *LOCAL.DB2.080103140511   
  41. Application Name: db2bp.exe   
  42. Requesting Agent ID: 5488   
  43. Coordinator Agent ID: 5488   
  44. Coordinator Partition: 0   
  45. Lock mode held: ..X   
  46. List of Active SQL Statements: Not available   
  47. List of Inactive SQL Statements from current UOW:   
  48. Entry: #1   
  49. Identification: UOW ID (6); Activity ID (2)   
  50. Package Schema: (NULLID )   
  51. Package Name: (SQLC2G13)   
  52. Package Version: ()   
  53. Section Entry Number: 201   
  54. SQL Type: Dynamic   
  55. Statement Type: DML, Select (blockable)   
  56. Effective Isolation: Cursor Stability   
  57. Statement Unicode Flag: No   
  58. Statement: SELECT LASTNAME, FIRSTNME, SALARY FROM EMPLOYEE   
  59. ORDER BY LASTNAME ASC   
  60. Entry: #2   
  61. Identification: UOW ID (6); Activity ID (1)   
  62. Package Schema: (NULLID )   
  63. Package Name: (SQLC2G13)   
  64. Package Version: ()   
  65. Section Entry Number: 203   
  66. SQL Type: Dynamic   
  67. Statement Type: DML, Insert/Update/Delete   
  68. Effective Isolation: Cursor Stability   
  69. Statement Unicode Flag: No   
  70. Statement: UPDATE EMPLOYEE SET SALARYSALARY = SALARY * 1.02  

这个锁定超时报告的开始部分与前面看到的相同。但是,这次的 Lock Owner 部分包含额外的、有价值的信息。在标题 List of Inactive SQL Statements from current UOW 下边,可以看到在发生锁定超时之前锁持有者的事务执行的所有 SQL 语句。从这组 SQL 语句中,可以找到导致问题锁定的语句。在这个场景中,使用 UPDATE 语句增加每个员工的工资。

 

注意,这个功能是对结合使用 db2cos 和 db2pd 方法的一个重大改进。使用 db2cos 与 db2pd 相结合的方法,只能看到锁持有者的应用程序执行的***一条语句 — 在这个场景中是对 EMPLOYEE 表的查询。但是由于查询并没有导致出现问题的独占锁,您仍然不知道是哪条语句导致了锁定。使用新方法 — DB2_CAPTURE_LOCKTIMEOUT 和死锁事件监视器 — 您拥有在锁拥有者的事务中执行的所有 SQL 语句的历史信息,这就可以将 UPDATE 确定为相关的语句。

使用锁定超时报告的提示

带有语句历史功能的死锁事件监视器适用于所有应用程序,会增加 DB2 数据库管理程序对监视器堆的大量使用。所以应该谨慎使用。您应该始终首先设置 DB2_CAPTURE_LOCKTIMEOUT=ON,然后只在必要的时候使用 DETAILS HISTORY 选项激活死锁事件监视器。

使用锁定超时报告时,您可能会注意到,DIAGPATH 中的锁定超时报告文件的数量在持续增加。DB2 不会删除这些报告文件,所以 DBA 需要删除它们或者将它们移动到不同的位置,以便在 DIAGPATH 的文件系统上始终有足够的空间。

即使拥有了锁定超时报告功能,也不是总能够轻松确定出导致锁定超时的原因。例如,如果锁定超时由静态 SQL 或 DB2 内部锁定引起时,就没有那么容易确定原因。DB2 9.5 文档的 Lock timeout reporting 一章提供了这些局限性的一个简短列表(参见下面的 参考资料)。但是,DB2 9.5 中的锁定超时报告绝对是一个许多 DBA 期待已久的功能,而且将大大简化对锁定超时的分析。
以上的相关内容就是对分析DB2 9.5中的锁定超时原因的介绍,望你能有所收获。

【编辑推荐】

  1. DB2数据库从Excel中读取数据举例
  2. DB2数据库双机的安装方法介绍
  3. DB2数据库开发常见问题解答
  4. DB2数据库的安装目录结构介绍
  5. shell抽取db2数据库数据的方法示例
责任编辑:佚名 来源: w3school.com.cn
相关推荐

2010-08-27 11:39:19

DB2锁定新特性

2009-03-10 10:31:26

DB2XMLpureXML

2010-09-01 09:40:33

DB2函数OLAP

2010-07-30 11:01:55

2010-08-05 09:03:27

DB2 9.5高可用性

2010-08-06 15:14:03

DB2 V9.5 新特

2010-07-28 10:22:44

DB2 9.5

2010-08-05 16:08:12

轻松掌握DB2 9.5

2009-03-11 14:59:17

数据库DB2数据库分区

2010-08-10 15:30:21

2010-09-07 10:36:56

DB2数据库

2009-06-04 17:53:24

DB2数据库单个会话锁定LOCKTIMEOUT

2010-11-03 15:35:27

DB2修改表

2010-11-02 16:25:55

DB2锁机制

2010-08-02 14:50:41

DB2数据库

2011-05-13 10:32:54

DB2数据库

2010-08-03 16:54:10

DB2 9.5

2010-08-20 11:28:45

DB2 -964问题

2011-05-27 14:28:33

DB2

2010-11-01 13:45:16

DB2数据库的优势
点赞
收藏

51CTO技术栈公众号