对DB2锁等待的正确分析与操作

数据库
此文章主要向大家讲述的是对DB2锁等待的实际操作流程的详细分析,以及对查找数据库DB2锁等待根源的描述,以下就是文章的主要内容讲述。

我们今天主要向大家讲述的是正确分析DB2锁等待的实际操作流程,锁,给人感觉是一个即安全又不大方便的技术,同样也是在数据库中发挥着他无可替代的作用,但是,不同的数据库对其有不同的实现方式。

当你习惯一个数据库的使用方式,去接触另外一个数据库时,就会感觉到诸多的不便。

每个开始接触DB2的人,或多或少的都有这样的感受,数据库中有那么多类型的锁,S,IS,NS,X,IX,SIX,NX,U,Z….从名字上看,很多差不多,如果你能都弄懂他的含义,并且在设计中考虑到,那当然是好的;如果你不是很理解他,没关系,大多数使用DB2数据库开发的人都不能完全理解他们,所以,你不用担心。作为一个DB2数据库使用比较习惯的人,这里分享下如何处理DB2锁等待问题,帮助大家解决使用DB2过程中遇到的锁问题。

 

下面,使用一个简单的例子来介绍下如何分析数据库的中的锁等待问题。

场景,查找数据库DB2锁等待的根源:

创建一个简单的表:

  1. db2 "create table test_lock (col int, col2 char(10))"  

开3个命令行的窗口

 

在窗口一执行:

  1. db2 +c "insert into test_lock values(1,'aaa')"   
  2. DB20000I SQL命令成功完成。 

在窗口二执行:

 

  1. db2 "select * from test_lock"  

我们看到了,很长时间没有返回,这就是很多人曾经问的一个问题,我执行了一个很简单的操作,数据库卡死,不返回,为什么?

 

我们使用窗口三进行分析:

db2 list applications show detail

 

XUXIAOF db2bp.exe 22 *LOCAL.DB2.090817071951 00012 1 0 4764 UOW 正在等待 2009-08-18 10:52:08.685167 IBM-L3F6 SAMPLE C:\DB2\NODE0000\SQL00001\

 

XUXIAOF db2bp.exe 68 *LOCAL.DB2.090817075736 00003 1 0 4464 锁定等待 2009-08-18 10:53:24.329893 IBM-L3F6 SAMPLE C:\DB2\NODE0000\SQL00001\

 

这个命令永远是你看锁问题最简单实用的一步,数据库中到底现在存在不存在DB2锁等待,一看就知道,如果有较长时间Lock-waiting(英文环境)状态或者锁定等待(中文环境)状态,则数据库存在锁定等待的应用,如上所示,窗口2不返回的原因可能是锁等待引起的,现在,我们用db2pd这个工具,来分析下具体锁在哪儿,也许,这才是我们最关心的。

 

  1. db2pd -d sample -locks show detail   
  2. Address TranHdl Lockname Type Mode Sts Owner Dur HoldCount Att ReleaseFlg   
  3. 0x7F8911B0 8 03000500040080020000000052 Row .NS W 2 1 0 0x00 0x00000001 TbspaceID 3 TableID 5 PartitionID 0 Page 640 Slot 4  

执行这个命令后,你也许会看到很多的锁,我为什么会找出这条呢?记住,你分析的入手点一定是正在等待的应用程序,也就是上面所列,状态(Sts)为W(waiting)的应用,也许在你的环境中你看到了很多,可以逐个分析。

【编辑推荐】

  1. DB2数据库优化过程中的实用策略的描述
  2. SQL Server到DB2连接服务器如何实现?
  3. DB2 admin管理员帐号删除的正确理解
  4. 对DB2数据库性能的理解误区描述
  5. DB2物化视图之MQT物化查询表的应用

 

责任编辑:佚名 来源: 清华大学出版社
相关推荐

2010-08-06 13:20:00

DB2锁等待

2010-08-04 17:10:37

DB2数据库

2010-07-28 09:21:25

DB2锁等待

2010-08-19 09:54:42

DB2死锁

2010-08-20 08:52:25

DB2死锁

2010-08-18 14:10:38

DB2入门

2010-08-10 08:42:35

DB2锁等待

2010-08-02 14:03:49

DB2驱动类型

2010-11-02 16:25:55

DB2锁机制

2010-08-10 13:36:00

2010-08-17 15:24:43

DB2数据移动

2010-08-11 15:04:03

DB2备份

2010-08-17 15:42:30

DB2 增量备份

2010-11-02 14:53:38

DB2权限

2010-08-18 15:14:08

DB2恢复命令

2010-08-17 09:18:29

DB2 备份

2010-08-09 16:16:58

DB2取得当前时间

2010-08-20 10:18:32

DB2自动增长主键

2010-07-28 14:16:43

DB2驱动类型

2010-08-05 11:29:04

java DB2
点赞
收藏

51CTO技术栈公众号