位置: 编程技术 - 正文

简单介绍SQL Server里的闩锁(简单介绍清明上河图)

编辑:rootadmin

推荐整理分享简单介绍SQL Server里的闩锁(简单介绍清明上河图),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:简单介绍春节的风俗,简单介绍蚂蚁的特点,简单介绍自己的句子,简单介绍春节的风俗,简单介绍一下自己,简单介绍自己的名字由来,简单介绍一下自己,简单介绍春节的风俗,内容如对您有帮助,希望把文章链接给更多的朋友!

在今天的文章里我想谈下SQL Server使用的更高级的,轻量级的同步对象:闩锁(Latch)。闩锁是SQL Server存储引擎使用轻量级同步对象,用来保护多线程访问内存内结构。文章的第1部分我会介绍SQL Server里为什么需要闩锁,在第2部分我会给你介绍各个闩锁类型,还有你如何能对它们进行故障排除。

为什么我们需要闩锁?闩锁首次在SQL Server 7.0里引入,同时微软首次引入了行级别锁(row-level locking)。对于行级别锁引入闩锁的概念是非常重要的,不然的话在内存中会出现丢失更新(Lost Updates)的现象。如我所说的,闩锁是存储引擎使用的轻量级同步对象,是SQL Server用来保护内存结构的。闩锁只不过是类似于多线程编程里的所谓的临界区(Critcal Section)概念。

在传统并发编程里,临界区是同时只能一个线程运行的代码。闩锁本身是个临界区的特殊版本,因为它允许多个并发读操作。在SQL Server的上下文里这意味着多个线程可以并发读取一个共享数据结构,例如内存中的页,但是写入共享数据结构必须是单个线程进行。

闩锁是用来协调数据库里多个线程物理执行,然而锁是基于选择的事务隔离级别,用来逻辑获得需要的隔离级别。作为开发者或DBA的你,你可以用不同方式影响锁——例如通过SQL Server里的隔离级别,或者通过各种可用锁提示。另一方面闩锁是不能以直接方式控制的。在SQL Server里没有闩锁提示,也没有可用闩锁隔离级别。下表是锁和闩锁之间的比较:

         锁(Locks)         闩锁(Latches)

控制……       事务              线程保护……     数据库内容          内存中数据结构模式……     共享的(Shared),      保持(Keep),         更新(Update),       共享的(Shared),

         排它的(Exclusive),     更新(Update),排它的(Exclusive),

         意向的(Intension)      销毁(Destroy)

死锁……  检测并解决(detection&resolution)  通过严谨代码来避免保持在……  锁管理器的哈希表(Hashtable)   保护的数据结构(Protected Data Structure)从表里可以看到,闩锁支持更细粒度保持(Keep)和销毁(Destroy)模式。保持闩锁主要用来引用计数,例如当你想知道在指定闩锁上有多少其它闩锁在等待。销毁闩锁是最有限制的一个(它甚至会阻塞保持闩锁),当闩锁被销毁时会用到,例如当惰性写入器(Lazy Writer)想要释放内存中的页时。我们先介绍下各种闩锁模式,然后说下各个闩锁模式的兼容性。

NL(空闩锁):

内部 未使用

KP(保持闩锁):

可以由多个任务同时持有 只被一个DT模式的闩锁阻塞

SH(共享闩锁):

读取数据页的时候使用 可以由多个任务同事持有 阻塞EX模式和DT模式的闩锁

UP(更新闩锁):

写入系统分配页面和tempdb的行版本化页面时使用 一个这种模式的闩锁只能被一个单独的任务持有

EX(排它闩锁):

写入数据页的时候使用 一个这种模式的闩锁只能被一个单独的任务持有

简单介绍SQL Server里的闩锁(简单介绍清明上河图)

DT(销毁闩锁):

很少使用 一个这种模式的闩锁只能被一个单独的任务持有

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_dfea.png" alt="查看图片" />

在SQL Server里,一致性不能只用锁来获得。SQL Server还是可以访问没被锁管理器保护的共享数据结构,例如页头。还有SQL Server基于闩锁基础的其他组件也是,有单线程代码路径。好了,我们继续讲解SQL Server里的各种闩锁类型,还有如何对它们进行故障排除。

闩锁类型与故障排除SQL Server区分3个不同闩锁类别

IO闩锁 缓冲区闩锁(BUF) 非缓冲区闩锁(Non-BUF)

我们来详细看下这3个不同类别。当在缓冲池的页读写操作未完成——即当你读自/写入你的存储子系统时(2者未同步),SQL Server会使用IO闩锁(I/O Latches)。对于这些I/O闩锁,SQL Server在统计信息里以PAGEIOLATCH_为前缀出现。你可以在DMV sys.dm_os_wait_stats 查看下这些闩锁类型的等待。

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_de.png" alt="查看图片" />

使用这些闩锁,SQL Server保证那些页不会并发多次读入缓存池,那些页也不会从缓存池忽略,在那些页需要被查询访问的时候。

除这些I/O闩锁外,SQL Server也支持所谓的缓存区闩锁(Buffer Latches),它用来保护缓冲池里页不会被并发运行的线程影响。这些闩锁,SQL Server使用它们来阻止内存中的丢失更新(Lost Updates)。没有这类闩锁,在缓存池里会有并发的读写页,它们会引发主内存里页的损坏。对于这些缓存闩锁,SQL Server在统计信息里以PAGELATCH_为前缀出现。你可以在DMV sys.dm_os_wait_stats 查看下这些闩锁类型的等待。这里最重要的是你涉及了主内存的竞争,因为他们的等待类型名称里不包含IO字样。

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_df1e1f.png" alt="查看图片" />

最后SQL Server内部使用所谓的非缓存区闩锁(Non-Buffer Latches)来保护除缓冲池外的共享数据结构。对于这些非缓存闩锁,SQL Server在统计信息里以LATCH_为前缀出现。你可以在DMV sys.dm_os_wait_stats 查看下这些闩锁类型的等待。

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_d.png" alt="查看图片" />

但在这个DMV里这些对于非缓存区闩锁的等待只是SQL Server内部使用的各个闩锁的概况信息,你可以在单独的DMV sys.dm_os_latch_stats找到更详细的信息。

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_dff.png" alt="查看图片" />

SQL Server 内部使用个闩锁来同步共享数据结构的访问。其中一个著名的闩锁是FGCB_ADD_REMOVE,它用来保护文件组的文件组控制阻塞( File Group Control Block (FGCB)),在以下特定操作期间:

文件增长(手动或自动) 增加/删除文件组文件 重新计算填充比重(Recalculating proportional fill weightings) 在循环分配期间,通过文件组的文件回收。当你看到这个闩锁排在前列是,你肯定有太多自动增长操作的问题,原因是你数据库糟糕的默认配置。当查询尝试读/写保护的数据结构且需要等待一个闩锁时,查询就会进入挂起状态,直到闩锁可以成功获取。因此查询经过的整个查询生命周期包括运行(RUNNING),挂起(SUSPENDED),可运行(RUNNABLE),最后再次运行(RUNNING)。因此,当查询长时间把持闩锁时,强制共享数据结构保护才有意义。那是因为改变查询状态也意味着进行Windows系统里的上下文切换,依据引入的CPU周期是个很昂贵的操作。

因此对于读写频繁或极短时间内的共享数据结构上放上闩锁没有意义。在这个情况下,需要的上下文切换会杀死SQL Server的整体性能,它需要花费太多的时间来完成整个查询生命周期(运行(RUNNING),挂起(SUSPENDED),可运行(RUNNABLE))。那就是是SQL Server引入的所谓自旋锁(Spinlocks)。锁管理器就是这样数据结构的好例子:当锁定或解锁数据对象(例如记录,页等)时只需要单个线程访问。但当你查看sys.dm_os_latch_stats时,你会发现没有闩锁保护锁管理器本身。锁管理器使用的哈希表里对应的哈希桶使用自旋锁来保护——LOCK_HASH自旋锁。通过锁管理器执行锁定和解锁操作前,必须获得自旋锁。

标签: 简单介绍清明上河图

本文链接地址:https://www.jiuchutong.com/biancheng/347419.html 转载请保留说明!

上一篇:简单介绍SQL Server中的自旋锁(简单介绍春节的风俗)

下一篇:为什么我们需要在SQL Server里更新锁(为什么我们需要政府)

  • 个人所得税信息采集怎么弄
  • 投资公司取得的投资收益属于销售额吗
  • 金融资产交易增值税
  • 电子税务局如何删除办税人员
  • 企业收到财政局退款需要开票吗
  • 冲红电子发票是什么意思
  • 利润是非限定净现值吗
  • 房地产企业预缴增值税怎么计算
  • 纳税人从两处取得收入汇算清缴可以扣除2个60000吗
  • 会计科目的设置
  • 小规模纳税人开具增值税专用发票
  • 税收返还要交税吗
  • 费用收入结转本年利润
  • 进项票失控对销项票有影响吗?
  • 账本印花税税金及附加怎么入账?
  • 公司仓库调拔结算会计分录.
  • 建筑业调试费进什么科目?
  • 工效挂钩企业工资税前扣除有何规定?
  • 非货币性资产交换差额计入什么科目
  • 企业怎么通过债务转让
  • 教育培训行业收入
  • 清算所得税申报表范本
  • 单位代扣公积金比例
  • 无形资产商标设计图片
  • 如何解决win7系统不稳定
  • php页面传值
  • 苹果客服人工24小时
  • win10开机强制进入高级选项怎么退出
  • 资本化的后续支出包括哪些项目
  • 格拉纳达的阿尔罕布拉宫用什么材料制成?
  • 定额发票丢失了怎么补办
  • 新政府会计制度科目解读
  • 财政拨款结转的二级科目有哪些
  • 电子税务局附加税退税在哪看
  • 企业通讯费补贴发放规定
  • 通用定额发票能当餐饮发票报销吗
  • 邀请客户参加会议
  • 企业资产的范围
  • sqlserver正则表达式用法
  • 递延所得税怎么计算
  • 现金流量表中的现金流量包括哪些
  • 贴现法付息的实际利息
  • 个体户查账征收个人所得税税率
  • 应付职工薪酬会计凭证
  • 专项资金的账务处理 借:银行存款 贷:其他应付款
  • 企业征收所得税会计分录
  • 逾期未认证的增值税发票处理办法
  • 以前年度损益调整是什么意思
  • 职工宿舍怎么入账
  • 专利年费可以减免吗
  • 母公司帮子公司代缴社保
  • 发票已开后 对方公司名称变更怎么处理?
  • 登记总分类账的依据有
  • 填制凭证的主要内容和注意事项
  • 常见ui
  • 跨国企业在国外设立工厂的战略地位
  • sql语句多行合并成一行
  • sql怎么分组查询
  • win7 64位系统插入磁盘提示“将磁盘插入驱动器”的解决方法
  • window组件在哪里
  • ubuntu屏幕突然变大
  • 当前用户已注销
  • 基于嵌入式linux的课程设计
  • linux常用桌面环境
  • unity 3d数学
  • linux dev/sr0
  • Unity3D游戏开发(第2版)pdf
  • 用球体模拟天空的游戏
  • 简介怎么写
  • 用jquery制作轮播图效果
  • include eigen
  • python中列表删除
  • IndicatorTabBar——可滑动的带指示条的TabBar
  • js 函数写法
  • jquery基本操作
  • 河南的省直
  • 房屋维修是什么职业
  • 税务登记时必须要填银行账号吗
  • 1国家税务总局
  • 地税逾期了怎么申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设