成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

DB2鎖機制深度分析

數據庫
學習DB2數據庫,DB2鎖機制是需要重點掌握的,下文對DB2鎖機制進行了詳盡的解讀,如果您對此方面感興趣的話,不妨一看。

DB2鎖機制對于DB2數據庫來說,有著舉足輕重的意義,下面就讓我們一起來了解一下什么是DB2鎖機制。

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

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

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

DB2 多粒度封鎖機制介紹

fenced1 鎖的對象

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

fenced2 鎖的策略

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

fencedfenced1 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鎖用于表上以允許未提交讀這一概念。

fencedfenced2 DB2行鎖的模式

fencedfenced3 DB2鎖的兼容性

fenced3 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等)。

DB2多粒度封鎖機制的監控

在DB2中對鎖進行監控主要有兩種方式,***種方式是快照監控,第二種是事件監控方式。
 

 

【編輯推薦】

DB2添加驗證約束的實現

使用DB2 sequence實現自動產生主鍵

DB2創建表空間的方式

Linux中DB2用戶組的介紹

DB2性能優化的十大注意事項

責任編輯:段燃 來源: 互聯網
相關推薦

2010-11-03 15:35:27

DB2修改表

2010-11-02 16:31:59

DB2鎖的屬性

2010-08-02 17:30:30

DB2鎖等待

2010-08-10 15:30:21

2010-11-04 15:43:49

DB2數據統計與分析系

2010-08-06 13:20:00

DB2鎖等待

2010-11-02 16:47:26

DB2鎖兼容性

2010-08-27 13:50:12

DB2安全機制

2010-11-02 16:39:32

DB2鎖的類型

2010-09-07 09:31:03

DB2數據庫鎖表

2012-12-07 10:19:56

IBMdW

2010-07-28 09:21:25

DB2鎖等待

2010-09-01 09:40:33

DB2函數OLAP

2011-05-27 14:28:33

DB2

2011-05-27 15:11:04

DB2

2010-08-26 11:37:38

DB2命令

2010-11-03 15:49:32

DB2刪除表

2010-11-01 13:45:16

DB2數據庫的優勢

2010-08-19 09:54:42

DB2死鎖

2010-08-11 09:14:33

DB2數據類型
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人在线视频网 | 亚洲a视频 | 国产成人精品高清久久 | 一区二区三区在线免费观看 | 日本免费一区二区三区 | 99免费在线 | 中文字幕视频在线 | 日韩在线视频一区二区三区 | 久草视频在线播放 | 久久天天躁狠狠躁夜夜躁2014 | 一区二区中文字幕 | 狠狠操狠狠干 | 在线午夜| 亚洲一区二区三区免费视频 | 日本久久久一区二区三区 | 一级片免费视频 | 久久手机在线视频 | 日韩在线日韩 | 欧美精品一区二区在线观看 | 国产精品久久久久久妇女 | 精品国产91乱码一区二区三区 | 欧美精品一区在线 | 欧美精品久久久久久久久久 | 国产日韩欧美电影 | 激情网站在线观看 | 91 久久| 天天碰夜夜操 | 成年精品 | 久久精品男人的天堂 | 成人免费视频观看视频 | 在线观看视频一区二区三区 | 亚洲综合无码一区二区 | 中文字幕亚洲视频 | 久久久一区二区三区 | 久久成人国产 | 久草影视在线 | 日韩中文在线观看 | 欧美日韩在线免费观看 | 亚洲精品一区二区 | 欧美美女爱爱视频 | 国产精品爱久久久久久久 |