设为首页 收藏本站
查看: 771|回复: 0

[经验分享] DB2 claim与drain

[复制链接]

尚未签到

发表于 2016-11-18 06:41:02 | 显示全部楼层 |阅读模式
DB2使用claim & drain来控制SQL与utility对数据库对象的访问。
claim说明有对象正在访问或是将要访问该对象,而drain则是在对象上面加一个drain lock,等所有的claimers执行完成以后,对该对象进行特定的处理操作。drain lock的目的是防止多个process同时drain一个对象,从而出现drain deadlock。
二者都是对象级别的,它独立于事务锁而存在。
需要注意的drain是action,即它也是一个claim,它发出drain的指令,拿到drain lock,然后就等待其他的claimers执行完成,然后执行自己的drained claim。?

Claims and drains for concurrency control
Claims and drains are taken at the object level only and not at the page or row level. DB2 utilities, commands, and some ALTER, CREATE, and DROP statements can take over
access to some DB2 objects independent of any transaction locks that are held on the object.
Claims and drains on an index unlike transaction locks, the claims and drains can be taken on indexes also. DB2 utilities, commands, and some ALTER, CREATE, and DROP statements can take over access to certain objects.
index上允许有drain和claim。
The following objects are subject to takeover by those operations:

  • Simple and segmented table spaces


  • Partitions of table spaces


  • LOB table spaces


  • XML table spaces


  • Non-partitioned index spaces


  • Partitions of index spaces


  • Logical partitions of non-partitioned indexes



A claim is a notification to DB2 that an object is being accessed. When an application first accesses an object, within a unit of work, it makes a claim on the
object. It releases the claim at the next commit point. Unlike a transaction lock, a claim normally does not persist past the commit point. To access the object in the next unit of work,
the application must make a new claim.(claim的生命周期在一个unit work)
However, an exception exists: If a cursor defined with the WITH HOLD clause is positioned on the claimed object, the claim is not released at a commit point.
A claim indicates activity on or interest in a particular page set or partition to DB2. Claims prevent drains from occurring until the claim is released.
Three classes of claims
Table 6-1 shows the three classes of claims and the actions that they allow.
Table 6-1 Claim classes and how DB2 uses them
Claim class Notification to DB2 that the following action is being performed on the object involved
Write Reading, updating, inserting, and deleting
Repeatable read Reading only, with repeatable read (RR) isolation
Cursor stability read Reading only, with read stability (RS), cursor stability (CS), or uncommitted read (UR) isolation

A drain is the action of taking over access to an object by preventing new claims and waiting for existing claims to be released.
A utility can drain a partition when applications are accessing it. The drain quiesces the applications by allowing each one to reach a commit point, but preventing any of them, or any
other applications, from making a new claim. drain允许原有claim一直活到commit point,但不允许新的claim。When no more claims exist, the process that drains (the drainer) controls access to the drained object. The applications that were drained can still hold transaction locks on the drained object, but they cannot make new claims until the drainer has finished.
Drained claim classes
A drainer does not always need complete control. It could drain the following combinations of
claim classes:
 Only the write claim class
 Only the repeatable read claim class
 All claim classes
For example, the CHECK INDEX utility needs to drain only writers from an index space and its associated table space. The RECOVER TABLESPACE utility, however, must drain all claim
classes from its table space. The REORG utility can drain either writers (with DRAIN WRITERS) or all claim classes (with DRAIN ALL).
How DB2 uses drain locks
A drain lock prevents conflicting processes from trying to drain the same object at the same time.
Processes that drain only writers can run concurrently, but a process that drains all claim classes cannot drain an object concurrently with any other process. To drain an object, a
drainer first acquires one or more drain locks on the object, one for each claim class that it needs to drain.(一个claim分配一个drain lock)
When the locks are in place, the drainer can begin after all processes with claims on the object have released their claims. A drain lock also prevents new claimers from accessing an object while a drainer has control of it.
Types of drain locks
Three types of drain locks on an object correspond to the three claim classes:

  •  Write


  •  Repeatable read


  •  Cursor stability read

In general, after an initial claim has been made on an object by a user, no other user in the system needs a drain lock. When the drain lock is granted, no drains on the object are in
process for the claim class needed, and the claimer can proceed.
The claimer of an object requests a drain lock in the following exceptional case: The claim is the first claim on an object before its data set has been physically opened. Here, acquiring the
drain lock ensures that no exception states prohibit allocating the data set.
For data sharing, when the claimer gets the drain lock, it makes its claim and releases the lock before beginning its processing.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-301793-1-1.html 上篇帖子: DB2维护手册 下篇帖子: 调优 DB2 UDB v8.1 及其数据库的最佳实践
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表