原文:
闩锁是应用在用户模式下,在读写锁结构应用在sql server 中用来保护内部结构。trace latch 是sql server 使用闩的例子,被trace controller 类创建并且使用。不管你是开着trace或者关了trace,当物理状态被修改的时候,都会分配一个x模式来阻止其他线程访问数据。
sql server 有个进程来监视某一些latch,如果负载比较重,并且是只读的访问,那么就可以变成子闩。
每个闩结构都包含了状态(当天的闩模式),等待队列,其他状态信息。每次要从闩上获取信息都要使用内部锁定(interlock)模式。那么有些闩就变成热点闩从而影响性能。
为了增加性能,那么就减少全局的信息
使用超闩锁和子闩锁,这样每个调度器分配一个 子闩锁。子闩锁访问超闩锁来获取信息,那么就不需要使用内部锁定的方式来访问被保护的对象。当调度器调用资源的时候,会通过超闩锁来重新定向到保护的对象。这种方式在只读访问能大大的提升性能,因为减少了热点。但是在写访问的时候,调度器必须对每个子闩都处理,并降级为普通的闩。
因此sql server 使用了自动升级闩和降级闩 来增加性能