青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

DB2診斷系列之---定位鎖等待問題

Posted on 2009-08-07 09:29 Prayer 閱讀(367) 評論(0)  編輯 收藏 引用 所屬分類: DB2
  在DB2應用中,我們經常會碰到sql執行很慢,但是數據庫cpu和內存使用率又不高的情況,類似的問題基本上由于鎖,排序等原因造成,本文主要描述如何去定位鎖等待問題,誰在鎖等待?等待誰持有的鎖?鎖在那個表?

  一、測試準備

  1、先在session1執行如下操作,創建測試表

  #db2 connect to eos
  #export DB2OPTIONS=+C
  #db2 "create table tacy_test (a int not null primary key,b varchar(10))"
  #db2 "insert into tacy_test values(1,'a')"
  #db2 "insert into tacy_test values(2,'a')"
  #db2 "insert into tacy_test values(3,'a')"
  #db2 "insert into tacy_test values(4,'a')"
  #db2 commit

  2、在session2執行如下操作

  #db2 connect to eos
  #export DB2OPTIONS=+C

  二、產生一個lock wait

  在session1做一個表更新:

  #db2 "update tacy_test set b='b' where a=4"

  sql執行成功

  在session2做同樣更新操作:

  #db2 "update tacy_test set b='c' where a=4"

  進程被掛起等待

  三、定位鎖等待

  1、先來看看應用的情況:

  #db2pd -db eos -applications

  Database Partition 0 -- Database EOS -- Active -- Up 0 days 07:37:37

  Applications:

  Address AppHandl [nod-index] NumAgents CoorPid Status C-AnchID C-StmtUID L-AnchID L-StmtUID Appid

  0x10140040 8 [000-00008] 1 8425 Lock-wait 80 2 66 1 *LOCAL.db2inst1.071124043739

  0x100CE540 7 [000-00007] 1 8358 UOW-Waiting 0 0 80 2 *LOCAL.db2inst1.071124043708

  可以看到有一個應用的狀態處于Lock-wait

  2、現在我們來看看應用在等什么

  #db2pd -db eos -locks showlock wait

  Database Partition 0 -- Database EOS -- Active -- Up 0 days 07:42:56

  Locks:

  Address TranHdl Lockname Type Mode Sts Owner Dur HldCnt Att Rlse

  0x2C8E0760 3 02001806078066020000000052 Row ..X W 2 1 0 0 0x0 TbspaceID 2 TableID 1560 RecordID 0x2668007

  鎖的類型為Row(行鎖),X鎖(排他鎖),下面是我們最關心的鎖的位置

  TbspaceID 2 TableID 1560 RecordID 0x2668007

  其中TbspaceID為表空間ID,TableID為表的ID,RecordID代表具體位置,全部應該是0x0266807,其中前面三個字節為page number,為0x02668,后面一個字節代表solt identifier,為0x07

  3、找到相應的表

  #db2 "select tbspace,tabschema,tabname,tableid,tbspaceid from syscat.tables where tbspaceid=2 and tableid=1560"

  TBSPACE TABSCHEMA TABNAME TABLEID TBSPACEID

  ------------ ----------- ---------- ------- ---------

  USERSPACE1 DB2INST1 TACY_TEST 1560 2

  1 record(s) selected.
  
  4、根據RecordID找到鎖在哪行

 

  db2提供了一個強大的數據分析工具db2dart,可以dump出相應的page數據

  #db2dart eos /dd /tsi 2 /oi 1560 /ps 157312p /np 1 /v y

  Warning: The database state is not consistent.

  Warning: Reorg rows MAY be due to the inconsistent state of the database.

  DB2DART Processing completed with warning(s)!

  Complete DB2DART report found in:

  /home/db2inst1/sqllib/db2dump/DART0000/EOS.RPT

  其中tsi為表空間id(2),oi為表id(1560),ps為page number(0x0266807),需要轉換為十進制,在結尾必須加p,np代表你要獲取的頁數,v為是否詳細輸出

  現在我們來看看EOS.RPT

  ______________________________________________________________________________

  _______ DART _______

  D a t a b a s e A n a l y s i s a n d R e p o r t i n g T o o l

  IBM DB2 6000

  ______________________________________________________________________________

  DART (V8.1.0) Report:

  2007-11-24-20.59.51.355893

  Database Name: EOS

  Report name: EOS.RPT

  Old report back-up: EOS.BAK

  Database Subdirectory: /opt/db2/db2inst1/NODE0000/SQL00001

  Operational Mode: Database Inspection Only (INSPECT)

  ______________________________________________________________________________

  ------------------------------------------------------------------------------

  Action option: DD

  Table-object-ID: 1560; Tablespace-ID: 2; First-page: 157312p; Number-pages: 1; Verbose: y

  Warning: The database state is not consistent.

  Warning: Reorg rows MAY be due to the inconsistent state of the database.

  Connecting to Buffer Pool Services...

  Table object report phase start.

  Dump format is verbose.

  ______________________________________

  Page 0 of object 1560 from table space 2.

  BPS Page Header:

  Page Data Offset = 48

  Page Data Length = 4048

  Page LSN = 0000 AE97 AE41

  Object Page Number = 0

  Pool Page Number = 157312

  Object ID = 1560

  Object Type = Data Object

  Data Page Header:

  Slot Count = 8

  Total Free Space = 2784

  Total Reserve Space = 0

  Youngest Reserve Space = n/a

  Youngest TID = n/a

  Free Space Offset = 2799

  Maximum Record Size = 23

  Data Records:

  Slot 0:

  Offset Location = 3996 (xF9C)

  Record Length = 32 (x20)

  Record Type = Data Object Header Control Record

  Page count = 1

  Object Creation LSN = 0000 AE97 800C

  Object State = x0000

  UDI Since Runstats = 0

  DART Field = x00000000

  Slot 1:

  Offset Location = 2992 (xBB0)

  Record Length = 1004 (x3EC)

  Record Type = Free Space Control Record

  Free space entries:

  0: 2884 (x0B44), 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC)

  4: 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC)

  8: 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC)

  省略。。。

  492: 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC)

  496: 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC), 4028 (x0FBC)

  Slot 2:

  Offset Location = 2916 (xB64)

  Record Length = 76 (x4C)

  Record Type = Table Directory Record

  MetaIndex Root Page = 157377

  Index Type = 2

  Table Descriptor Pointer -- Page 157312 Slot 3

  Max Insert Search = 0

  Flags = x02000200

  bit representation = 00000010 00000000 00000010 00000000

  Check pending info:

  Constraint status = x00

  Constraint RID = Page 0 Slot 0

  last BID = x00000000

  Slot 3:

  Offset Location = 2892 (xB4C)

  Record Length = 24 (x18)

  Record Type = Table Description Record

  Number of Columns = 2

  Column 1:

  Type is Long Integer

  Length = 4

  Prohibits NULLs

  Prohibits Default

  Fixed offset: 0

  Column 2:

  Type is Fixed Length Character String

  Length = 10

  Allows NULLs

  Prohibits Default

  Fixed offset: 4

  Slot 4:

  Offset Location = 2869 (xB35)

  Record Length = 23 (x17)

  Record Type = Table Data Record (FIXEDVAR)

  Fixed part length value = 15

  Column 1:

  Fixed offset: 0

  Type is Long Integer

  Value = 1

  Column 2:

  Fixed offset: 4

  Type is Fixed Length Character String

  61202020 20202020 2020 a

  Slot 5:

  Offset Location = 2846 (xB1E)

  Record Length = 23 (x17)

  Record Type = Table Data Record (FIXEDVAR)

  Fixed part length value = 15

  Column 1:

  Fixed offset: 0

  Type is Long Integer

  Value = 2

  Column 2:

  Fixed offset: 4

  Type is Fixed Length Character String

  61202020 20202020 2020 a

  Slot 6:

  Offset Location = 2823 (xB07)

  Record Length = 23 (x17)

  Record Type = Table Data Record (FIXEDVAR)

  Fixed part length value = 15

  Column 1:

  Fixed offset: 0

  Type is Long Integer

  Value = 3

  Column 2:

  Fixed offset: 4

  Type is Fixed Length Character String

  61202020 20202020 2020 a

  Slot 7:

  Offset Location = 2800 (xAF0)

  Record Length = 23 (x17)

  Record Type = Table Data Record (FIXEDVAR)

  Fixed part length value = 15

  Column 1:

  Fixed offset: 0

  Type is Long Integer

  Value = 4

  Column 2:

  Fixed offset: 4

  Type is Fixed Length Character String

  61202020 20202020 2020 a

  Slots Summary: Total=8, In-use=8, Deleted=0.

  Table object report phase end.

  ______________________________________

  DB2DART Processing completed with warning(s)!

  Warning(s) detected during processing.

  ______________________________________

  Complete DB2DART report found in:

  /home/db2inst1/sqllib/db2dump/DART0000/EOS.RPT

  _______ D A R T P R O C E S S I N G C O M P L E T E _______

  找到Solt 7 (0x07),ok,你現在可以清楚的知道應用等待的Row為(4,a)

  總結

  通過上面的方法,我們簡單描述了一個db2鎖問題的定位方法,希望能給大家在分析和定位應用性能問題的時候起到一定的幫助

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            日韩一区二区电影网| 久久先锋影音av| 亚洲国产婷婷香蕉久久久久久99| 亚洲国产成人av好男人在线观看| 性做久久久久久久免费看| 久久在线免费| 国产精品中文字幕在线观看| 国产欧美精品一区| 亚洲一二三四区| 亚洲人成网站999久久久综合 | 美女黄毛**国产精品啪啪| 国产精品一区免费视频| 亚洲夜晚福利在线观看| av成人激情| 欧美日韩中文字幕在线视频| aaa亚洲精品一二三区| 亚洲日本精品国产第一区| 欧美激情一区二区三区在线视频观看 | 久久久国产精品一区二区中文| 国产一区 二区 三区一级| 欧美一区二区三区免费观看视频| 亚洲视频一二| 国产精品久久久久91| 亚洲欧美视频在线观看| 亚洲视频你懂的| 国产欧美日韩另类视频免费观看| 欧美亚洲日本一区| 欧美一区二区在线免费播放| 国产一区二区0| 麻豆精品在线视频| 久热精品视频| 99精品视频免费| 亚洲综合精品自拍| 国产一区二区久久精品| 免费在线亚洲欧美| 欧美激情免费观看| 亚洲欧美电影在线观看| 亚洲专区在线| 一区二区亚洲欧洲国产日韩| 欧美激情性爽国产精品17p| 欧美激情在线观看| 午夜精品福利一区二区三区av| 午夜精品久久久久久久蜜桃app | 亚洲激情专区| 99亚洲一区二区| 国产一区二区三区久久悠悠色av | 国产综合激情| 亚洲欧洲另类国产综合| 国产精品久久久久久久久婷婷| 久久精品国产免费| 欧美国产免费| 久久精品毛片| 欧美日韩色婷婷| 另类激情亚洲| 国产精品一区二区在线观看网站| 久久久之久亚州精品露出| 久久精品一区二区三区四区| 欧美一区二区三区免费视| 久久丁香综合五月国产三级网站| 最新日韩在线视频| 亚洲欧洲av一区二区| 亚洲精品在线视频观看| 亚洲午夜激情网页| 亚洲黄色有码视频| 午夜精品影院| 亚洲调教视频在线观看| 久久永久免费| 欧美在线不卡| 欧美日韩性生活视频| 免费在线欧美视频| 国产亚洲欧美一区二区三区| 野花国产精品入口| 亚洲国产精品黑人久久久| 亚洲综合首页| 亚洲一区二区久久| 欧美激情bt| 亚洲成人资源| 亚洲国产日韩一区| 久久久亚洲国产美女国产盗摄| 午夜精品视频在线| 欧美日本一区| 亚洲二区免费| 亚洲国产精品999| 久久午夜色播影院免费高清| 久久精品国产亚洲精品| 国产精品一区免费观看| 亚洲视频综合| 亚洲自拍偷拍网址| 欧美视频一二三区| 一区二区免费看| 亚洲一区二区三区四区中文| 欧美日韩伦理在线免费| 亚洲人成网站777色婷婷| 亚洲精品四区| 欧美精品videossex性护士| 欧美激情第五页| 亚洲三级色网| 欧美精品大片| 日韩一级片网址| 日韩视频一区二区三区在线播放 | 国产精品一二三四| 亚洲欧美日韩一区二区在线| 久久福利一区| 国产一区二区三区四区在线观看 | 久久免费少妇高潮久久精品99| 国产亚洲欧美一区在线观看 | 伊人色综合久久天天| 久久午夜国产精品| 91久久久一线二线三线品牌| 日韩午夜av在线| 欧美日韩中字| 香蕉久久精品日日躁夜夜躁| 久久理论片午夜琪琪电影网| 在线看片欧美| 欧美日韩999| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美成人免费在线| 欧美成人情趣视频| 久久爱www久久做| 鲁大师影院一区二区三区| 你懂的成人av| 99精品欧美一区二区三区| 欧美激情一区二区在线 | 性视频1819p久久| 国产精品一区二区久久精品| 欧美亚洲一区二区在线观看| 久久综合色影院| 在线亚洲精品福利网址导航| 国产欧美三级| 欧美成人在线网站| aa日韩免费精品视频一| 欧美国产日韩一区二区| 中日韩在线视频| 久久伊伊香蕉| 一本久久青青| 激情亚洲网站| 国产精品videosex极品| 久久久久久穴| 亚洲视频网站在线观看| 欧美成人精品激情在线观看| 亚洲一区在线播放| 亚洲成人在线视频网站| 国产精品卡一卡二| 免费成人你懂的| 午夜视频一区在线观看| 亚洲人成在线免费观看| 久久av一区二区三区| 99国产一区二区三精品乱码| 国产综合18久久久久久| 国产精品久久久一区二区| 六十路精品视频| 亚洲欧美清纯在线制服| 亚洲精品综合久久中文字幕| 久久亚洲捆绑美女| 午夜精品福利在线观看| 亚洲天堂av电影| 亚洲国产小视频在线观看| 国产亚洲精品v| 国产精品二区二区三区| 欧美激情女人20p| 麻豆国产精品va在线观看不卡| 一区二区三区视频观看| 亚洲国产小视频| 欧美成人精品高清在线播放| 久久久最新网址| 久久精品道一区二区三区| 亚洲欧美精品suv| 亚洲一区二区3| 国产精品99久久不卡二区| 亚洲欧洲一区二区三区在线观看| 国产一区二区欧美日韩| 国产精品中文在线| 国产精品一区=区| 国产精品一区二区三区观看 | 久久av一区二区三区亚洲| 欧美亚洲网站| 性18欧美另类| 欧美在线影院| 久久久久国产一区二区三区| 久久国产精品久久国产精品| 欧美亚洲视频| 久久伊人亚洲| 欧美综合第一页| 亚洲天堂av在线免费| 亚洲一区二区三区涩| 亚洲调教视频在线观看| 亚洲欧美视频一区| 欧美一区1区三区3区公司| 亚欧成人在线| 午夜精品久久久久| 午夜国产精品视频| 久久aⅴ国产紧身牛仔裤| 欧美在线视屏| 国产一区二区精品| 欧美三级中文字幕在线观看| 亚洲天堂成人| 欧美中日韩免费视频| 国产精品一区二区在线观看网站 | 亚洲欧美日韩国产综合| 中文国产成人精品|