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

Prayer

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

DB2和 Oracle的并發控制(鎖)比較

Posted on 2009-04-27 11:02 Prayer 閱讀(324) 評論(0)  編輯 收藏 引用 所屬分類: 數據庫,SQLDB2

2005 年 12 月 26 日

在實際的生產運行環境中,筆者在國內很多客戶現場都看到開發人員和系統管理人員遇到很多有關于鎖而引起的性能問題,進而被多次問起DB2和Oracle中鎖的區別比較問題,筆者根據自己在工作中對DB2和Oracle數據庫的使用經驗積累寫下這篇文章。

1 引言

在關系數據庫(DB2,Oracle,Sybase,Informix和SQL Server)最小的恢復和交易單位為一個事務(Transactions),事務具有ACID(原子性,一致性,隔離性和永久性)特征。關系數據庫為了確保并發用戶在存取同一數據庫對象時的正確性(即無丟失更新、可重復讀、不讀"臟"數據,無"幻像"讀),數據庫中引入了并發(鎖)機制。基本的鎖類型有兩種:排它鎖(Exclusive locks記為X鎖)和共享鎖(Share locks記為S鎖)。

排它鎖:若事務T對數據D加X鎖,則其它任何事務都不能再對D加任何類型的鎖,直至T釋放D上的X鎖;一般要求在修改數據前要向該數據加排它鎖,所以排它鎖又稱為寫鎖。

共享鎖:若事務T對數據D加S鎖,則其它事務只能對D加S鎖,而不能加X鎖,直至T釋放D上的S鎖;一般要求在讀取數據前要向該數據加共享鎖,所以共享鎖又稱為讀鎖。

2 DB2 多粒度封鎖機制介紹

2.1 鎖的對象

DB2支持對表空間、表、行和索引加鎖(大型機上的數據庫還可以支持對數據頁加鎖)來保證數據庫的并發完整性。不過在考慮用戶應用程序的并發性的問題上,通常并不檢查用于表空間和索引的鎖。該類問題分析的焦點在于表鎖和行鎖。

2.2 鎖的策略

DB2可以只對表進行加鎖,也可以對表和表中的行進行加鎖。如果只對表進行加鎖,則表中所有的行都受到同等程度的影響。如果加鎖的范圍針對于表及下屬的行,則在對表加鎖后,相應的數據行上還要加鎖。究竟應用程序是對表加行鎖還是同時加表鎖和行鎖,是由應用程序執行的命令和系統的隔離級別確定。

2.2.1 DB2表鎖的模式

DB2在表一級加鎖可以使用以下加鎖方式:


表一:DB2數據庫表鎖的模式

下面對幾種表鎖的模式進一步加以闡述:

IS、IX、SIX方式用于表一級并需要行鎖配合,他們可以阻止其他應用程序對該表加上排它鎖。

  • 如果一個應用程序獲得某表的IS鎖,該應用程序可獲得某一行上的S鎖,用于只讀操作,同時其他應用程序也可以讀取該行,或是對表中的其他行進行更改。
  • 如果一個應用程序獲得某表的IX鎖,該應用程序可獲得某一行上的X鎖,用于更改操作,同時其他應用程序可以讀取或更改表中的其他行。
  • 如果一個應用程序獲得某表的SIX鎖,該應用程序可以獲得某一行上的X鎖,用于更改操作,同時其他應用程序只能對表中其他行進行只讀操作。

S、U、X和Z方式用于表一級,但并不需要行鎖配合,是比較嚴格的表加鎖策略。

  • 如果一個應用程序得到某表的S鎖。該應用程序可以讀表中的任何數據。同時它允許其他應用程序獲得該表上的只讀請求鎖。如果有應用程序需要更改讀該表上的數據,必須等S鎖被釋放。
  • 如果一個應用程序得到某表的U鎖,該應用程序可以讀表中的任何數據,并最終可以通過獲得表上的X鎖來得到對表中任何數據的修改權。其他應用程序只能讀取該表中的數據。U鎖與S鎖的區別主要在于更改的意圖上。U鎖的設計主要是為了避免兩個應用程序在擁有S鎖的情況下同時申請X鎖而造成死鎖的。
  • 如果一個應用程序得到某表上的X鎖,該應用程序可以讀或修改表中的任何數據。其他應用程序不能對該表進行讀或者更改操作。
  • 如果一個應用程序得到某表上的Z鎖,該應用程序可以讀或修改表中的任何數據。其他應用程序,包括未提交讀程序都不能對該表進行讀或者更改操作。

IN鎖用于表上以允許未提交讀這一概念。

2.2.2 DB2行鎖的模式

除了表鎖之外,DB2還支持以下幾種方式的行鎖。


表二:DB2數據庫行鎖的模式

2.2.3 DB2鎖的兼容性


表三:DB2數據庫表鎖的相容矩陣


表四:DB2數據庫行鎖的相容矩陣

下表是筆者總結了DB2中各SQL語句產生表鎖的情況(假設缺省的隔離級別為CS):



2.3 DB2鎖的升級

每個鎖在內存中都需要一定的內存空間,為了減少鎖需要的內存開銷,DB2提供了鎖升級的功能。鎖升級是通過對表加上非意圖性的表鎖,同時釋放行鎖來減少鎖的數目,從而達到減少鎖需要的內存開銷的目的。鎖升級是由數據庫管理器自動完成的,有兩個數據庫的配置參數直接影響鎖升級的處理:

locklist--在一個數據庫全局內存中用于鎖存儲的內存。單位為頁(4K)。

maxlocks--一個應用程序允許得到的鎖占用的內存所占locklist大小的百分比。

鎖升級會在這兩種情況下被觸發:

  • 某個應用程序請求的鎖所占用的內存空間超出了maxlocks與locklist的乘積大小。這時,數據庫管理器將試圖通過為提出鎖請求的應用程序申請表鎖,并釋放行鎖來節省空間。
  • 在一個數據庫中已被加上的全部鎖所占的內存空間超出了locklist定義的大小。這時,數據庫管理器也將試圖通過為提出鎖請求的應用程序申請表鎖,并釋放行鎖來節省空間。
  • 鎖升級雖然會降低OLTP應用程序的并發性能,但是鎖升級后會釋放鎖占有內存并增大可用的鎖的內存空間。

鎖升級是有可能會失敗的,比如,現在一個應用程序已經在一個表上加有IX鎖,表中的某些行上加有X鎖,另一個應用程序又來請求表上的IS鎖,以及很多行上的S鎖,由于申請的鎖數目過多引起鎖的升級。數據庫管理器試圖為該應用程序申請表上的S鎖來減少所需要的鎖的數目,但S鎖與表上原有的IX鎖沖突,鎖升級不能成功。

如果鎖升級失敗,引起鎖升級的應用程序將接到一個-912的SQLCODE。在鎖升級失敗后,DBA應該考慮增加locklist的大小或者增大maxlocks的百分比。同時對編程人員來說可以在程序里對發生鎖升級后程序回滾后重新提交事務(例如:if sqlca.sqlcode=-912 then rollback and retry等)。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲第一福利社区| 亚洲一区在线观看免费观看电影高清| 亚洲久久在线| 亚洲国产精品尤物yw在线观看| 亚洲自拍偷拍一区| 韩国在线一区| 韩国成人福利片在线播放| 国产一区91精品张津瑜| 欧美ed2k| 中文国产成人精品| 久久国产主播精品| 亚洲深夜福利网站| 1769国产精品| 国产精品v欧美精品∨日韩| 欧美人与性动交a欧美精品| 欧美性jizz18性欧美| 国产中文一区二区| 亚洲日本精品国产第一区| 国产精品一区二区在线观看网站 | 亚洲人妖在线| 在线视频精品一区| 欧美美女视频| 亚洲欧美国产高清| 裸体歌舞表演一区二区| 欧美一级电影久久| **网站欧美大片在线观看| 欧美极品色图| 国产乱码精品1区2区3区| 欧美国产视频日韩| 国产精品五月天| 91久久国产自产拍夜夜嗨| 激情久久综合| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 亚洲一区二区免费| 久久久久青草大香线综合精品| 亚洲高清免费视频| 欧美bbbxxxxx| 亚洲婷婷国产精品电影人久久| 91久久精品美女| 欧美大片一区| 欧美一区二区三区另类| 欧美日韩另类视频| 亚洲欧洲精品一区| 另类春色校园亚洲| 欧美一区二区三区在线视频| 欧美日韩在线看| 欧美日韩国产黄| 在线免费观看欧美| 久久五月婷婷丁香社区| 亚洲影视在线| 国产精品久久久久久影视| 一区二区高清视频| 最新亚洲一区| 夜夜嗨网站十八久久| 欧美大秀在线观看| 亚洲第一视频| 一本久久综合| 亚洲国产人成综合网站| 一本久久知道综合久久| 女同性一区二区三区人了人一| 国模精品娜娜一二三区| 久久国产一区二区| 久久久久久9| 欧美大片免费观看在线观看网站推荐| 国产一区二区日韩精品欧美精品| 午夜日韩av| 麻豆国产精品一区二区三区| 老牛国产精品一区的观看方式| 午夜精品网站| 欧美v日韩v国产v| 欧美精品国产| 国产精品99久久久久久白浆小说 | 亚洲自拍偷拍视频| 国产伦精品一区二区| 国内精品一区二区| 日韩一级二级三级| 午夜视频在线观看一区二区三区| 一区二区三区欧美在线| 国产精品嫩草影院av蜜臀| 狠狠久久亚洲欧美专区| 久久一二三四| 在线视频你懂得一区二区三区| 欧美日韩视频在线| 亚洲国产精品成人精品| 一区二区三区国产| 久久久久久九九九九| 久久精品99国产精品| 亚洲激情社区| 国产精品99久久久久久宅男 | 国产一级揄自揄精品视频| 最新日韩中文字幕| 亚欧成人在线| 亚洲国产成人porn| 欧美精品在线看| 欧美一区二区高清| 日韩午夜免费视频| 美女国产一区| 亚洲一区二区三区高清| 久久久久久穴| 亚洲欧美综合另类中字| 蜜桃av噜噜一区| 欧美一级视频免费在线观看| 欧美chengren| 亚洲精品国精品久久99热| 一区二区三区精品国产| 欧美日韩麻豆| 亚洲精品一区中文| 亚洲综合色自拍一区| 亚洲精品一区二区三| 欧美h视频在线| 国产精品二区二区三区| 国产精品99久久99久久久二8| 欧美黑人在线观看| 国产精品尤物福利片在线观看| 亚洲一区二区三区涩| 亚洲精品美女免费| 狠狠色丁香婷综合久久| 中国亚洲黄色| 一区二区三区欧美视频| 99成人免费视频| 欧美日韩精品久久| 另类欧美日韩国产在线| 久久久女女女女999久久| 亚洲无人区一区| 亚洲在线国产日韩欧美| 亚洲青涩在线| 亚洲综合清纯丝袜自拍| 亚洲精品乱码久久久久| 欧美国产一区二区在线观看| 亚洲国产裸拍裸体视频在线观看乱了 | 久久米奇亚洲| 久久精品国产亚洲高清剧情介绍| 欧美日韩一二三区| 亚洲精品中文字幕有码专区| 91久久综合| 女仆av观看一区| 一区二区三区四区五区在线| 日韩一级精品视频在线观看| 91久久精品视频| 噜噜噜在线观看免费视频日韩| 嫩草伊人久久精品少妇av杨幂| 国产无一区二区| 久久精品国产久精国产思思| 久久久久久久久一区二区| 一区二区三区自拍| 裸体歌舞表演一区二区| 亚洲人成网站999久久久综合| 日韩视频在线观看一区二区| 欧美片第一页| 一区二区三区视频免费在线观看| 在线亚洲精品| 国产精品午夜视频| 亚洲大片av| 日韩视频永久免费观看| 欧美视频在线观看视频极品| 亚洲综合国产精品| 亚洲黄色毛片| 欧美激情综合色| 亚洲一区二区精品视频| 久久av免费一区| 欧美女同在线视频| 在线亚洲欧美| 久久久噜久噜久久综合| 亚洲第一黄网| 午夜视频一区| 一区二区精品| 久久精品99国产精品酒店日本| 久久久亚洲欧洲日产国码αv| 亚洲国产精品第一区二区三区| 亚洲一区二区动漫| 久久全国免费视频| 一本色道久久88亚洲综合88| 国产精品午夜国产小视频| 久久综合成人精品亚洲另类欧美| 亚洲精品中文字幕女同| 狼人天天伊人久久| 亚洲视频你懂的| 亚洲丁香婷深爱综合| 性做久久久久久| 国产精品99久久久久久久久久久久| 久久久在线视频| 一区二区三区蜜桃网| 猛男gaygay欧美视频| 国产一区二区三区免费观看| 老司机精品久久| 亚洲欧美日韩综合国产aⅴ| 亚洲欧美中日韩| 欧美美女操人视频| 亚洲人成毛片在线播放| 亚洲肉体裸体xxxx137| 久久成人国产精品| 亚洲美女在线视频| 欧美国产乱视频| 媚黑女一区二区| 男同欧美伦乱| 国产精品国产三级国产| 久久精品国产综合| 女人天堂亚洲aⅴ在线观看| 一区二区三区欧美视频| 91久久在线视频|