SQL 2014新特性- Delayed durability

原文:SQL 2014新特性- Delayed
durability

ACID 是数据库的基本属性。其中的D是指"持久性":只要事务已经提交,对应的数据修改就会被保存下来,即使出现断电等情况,当系统重启后之前已经提交的数据依然能够反映到数据库中。

那么D特性是如何在SQL Server中实现的呢?SQL Server使用write-ahead
logging的方式,保证日志记录会先于数据记录固化到磁盘中。当事务提交后,只有当日志记录固化到磁盘时,才会向客户端返回提交成功的消息,至于相应的数据记录,会通过异步的方式后续写入到磁盘中。如果在此期间发生断电等故障,那么就会出现以下两种情况:

  1. 日志已经写入到磁盘(committed),但数据没有写入:

    系统重启后进行redo操作,通过读取日志,来将没有固化到数据文件的信息写入到数据文件。


  2. 部分日志已经写入到磁盘(uncommitted),数据部分写入或没有写入

    系统重启后执行undo操作,将没有提交的事务对应的数据从数据文件中清除。

这样就保证了已经提交的事务不会丢失。

Delayed
durability

SQL Server
2014中引入了一个新的特性,叫做Delayed durability(也称作lazy commit),颠覆了之前提到的概念。通过Delayed
durability,可以让日志记录按照一定规律异步地写入到日志文件中,避免日志磁盘写入过于频繁。这样就以牺牲Durability来换取性能

应用场景:

使用该特性的前提是您的应用可以容忍一定程度的数据丢失。

日志磁盘出现系统瓶颈。

由于日志磁盘性能问题,导致事务无法提交,导致相应的资源(memory,lock等)无法释放引发的资源竞争

Delayed Durability有以下特性:

  1. 一旦事务提交,事务中的数据变更对其他事务(包含full durable
    transaction和delayed durability
    transaction)可见。具体请参考isolation level
    http://msdn.microsoft.com/en-us/library/dn133175.aspx

  2. 事务的持久性(durability)依赖于日志记录是否固化到磁盘。

  3. 内存中的日志记录只有在任意以下情况发生时才会固化到磁盘:

    1. )Full durable transaction进行了数据变更,并且commit.

    2. )执行了sp_flush_log存储过程.

    3. )Log buffer满了,日志记录也会固化到磁盘.

如果1)或2)出现两次,那么SQLSERVER会保证第一次之前的Delayed durability
transaction的数据变更已经被固化到了磁盘。

如何使用Delayed
durability

Delayed durability是一个数据库级别的特性,默认是禁用的,我们首先要开启这个选项。




ALTER DATABASE [DDtest] SET DELAYED_DURABILITY
= FORCED|Allowed|Disabled

如果是forced,那么该数据库内所有的事务都强制使用delayed durability;如果是allowed,那么delayed durability和full
durable transaction可以同时存在;如果是disabled,那么无法使用delayed durability.

当该属性发生变化后,errorlog中也会有相应的记录

Setting database option
delayed_durability to forced for database ‘DDtest‘.

Setting database option
delayed_durability to allowed for database ‘DDtest‘.

Setting database option
delayed_durability to disabled for database ‘DDtest‘.

如果数据库的DELAYED_DURABILITY为Allowed,我们可以在语句级别进行控制,否则就要遵循数据库的设定了(如果语句的设定和数据库级别设定冲突,那么SQL Server会使用数据库级别的设定)。

事例

将数据的
DELAYED_DURABILITY设置为Allowed

ALTER
DATABASE
[DDtest] SET
DELAYED_DURABILITY
= Allowed

创建一张表,并循环插入1000行数据,每次插入都是一个单独的事务

create table ta(col int)

declare @N int=0

while @n<1000

begin

begin tran

insert ta values(1)

commit tran with(delayed_durability=off)

set @N+=1

print cast(@N as
varchar(1000))

end

开启Process Monitor,监控对数据库日志文件的操作。

一共对日志文件进行了1012次的写入操作,也就是每次commit都会立刻固化到日志文件

下面比较一下使用delayed durability的情况

declare @N int=0

while @n<1000

begin

begin tran

insert ta values(1)

commit tran with(delayed_durability=on)

set @N+=1

print cast(@N as
varchar(1000))

end

1000个事务只触发了32次写入,大大地减少了对日志文件的写入操作。

注意事项

  1. 当系统不忙时,也会主动将delayed
    durability的日志记录固化到磁盘。但目前不知道如何判断"不忙"这个标准。

  2. checkpoint不会将delayed
    durability的日志记录固化到磁盘。

  3. SQL Server正常关闭不会将delayed
    durability的日志记录固化到磁盘,也就说正常关闭也可能会导致数据丢失,建议之前先执行sp_flush_log

SQL 2014新特性- Delayed durability,布布扣,bubuko.com

时间: 2024-10-24 11:26:16

SQL 2014新特性- Delayed durability的相关文章

SQL Server 2014新特性——Buffer Pool扩展

Buffer Pool扩展 Buffer Pool扩展是buffer pool 和非易失的SSD硬盘做连接.以SSD硬盘的特点来提高随机读性能. 缓冲池扩展优点 SQL Server读以随机读为主,SQL Server IO分为2部分:buffer pool管理方式,和buffer pool. SQL Server 从磁盘中读入数据,并且存放在buffer pool中以供读取和修改,修改完之后脏数据还是放在buffer pool中,当内存紧张执行lazy write把脏数据写入磁盘,并且释放内存

谈谈我的微软特约稿:《SQL Server 2014 新特性:IO资源调控》

原文:谈谈我的微软特约稿:<SQL Server 2014 新特性:IO资源调控> 一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 篡写经历(Experience) 特约稿正文(Content-body) 第一部分:生活中资源调控器: 第二部分:SQL Server中资源调控器: 第三部分:SQL Server资源调控器运用场景—CPU: 第四部分:SQL Server资源调控器运用场景—IO: 第五部分:总结: 第六部分:作者简介:

visual studio 2014 新特性

原文如下: Visual Studio "14" CTP Today, we are making available a first community technology preview of the next version of Visual Studio, codenamed Visual Studio "14".  This early build is focused on enabling feedback and testing from the

SQL Server2012新特性概述

公司最近要升级数据库,SQL Server 2008R2-->2012.再开始升级之前先找了点资料分析一下2012的新特性和功能,提前预热一下. 2012中主要关注一下三个领域: 性能:改进的核心支持.列存储索.更强的压缩能力和alwayson等功能: 自助服务:借助于新的数据探索工具(如Power View),SQL Azure Bussiness Intellingence(BI).数据质量和主数据选项,以及PowerPivot for SharePoint 的改进,使用户在任何时候任何地方

SQL Server 2014新特性:其他

AlwaysOn 增强功能 SQL Server 2014 包含针对 AlwaysOn 故障转移群集实例和 AlwaysOn 可用性组的以下增强功能: “添加 Azure 副本向导”简化了用于 AlwaysOn 可用性组的混合解决方案创建.有关详细信息,请参阅使用“添加 Azure 副本向导”(SQL Server). 辅助副本的最大数目从 4 增加到 8. 断开与主副本的连接时,或者在缺少群集仲裁期间,可读辅助副本现在保持可用于读取工作负荷. 故障转移群集实例 (FCI) 现在可使用群集共享卷

Atitit.数据库新特性战略规划 mssql sql server 2008 SQL2012 SQL2014

Atitit.数据库新特性 mssql sql server 2008 SQL2012 SQL2014 1. Sql2012 新特性 1 1.1. 增加了Sequence对象. 1 1.2. 新的分页查询语法.offset和fetch 1 1.3. OVER子句的增强和新增一些分析函数. 之前OVER子句是用于RANK,ROW_NUMBER等排名函数,现在OVER子句得到了大大的增强, 可以将OVER子句应用到聚合函数中,也增加了一些分析函数. 2 1.4. 增强的审计功能 2 1.5. 增强的

22. SQL -- SQL Server 2005 和SQL Server 2008新特性

SQL SERVER 2005 与SQL SERVER 2008 新特性   SQLSERVER 2005 新特性 Enhanced Data Types:存储最大8K-2G Partitioned Table(分区表):数据拆分管理 背景:一个公司,有目前现存数据以及历史数据,各在一台SER 上,服务器访问方式: SQL 2000 TABLE 1:在一张table 中,对数据进行分区 Enhanced Indexing Features SER 1 SER 2 现存数据 TABLE 1 TAB

微软 ASP.NET vNext MVC6 Web API3 新特性

今天讲课系统NET vNext 新特性ASP.NET vNext新特性, MVC6, Web API 3.0新特性,Roslyn编译器 ..NET Native.nGEN.JIT64和RyuJIt新特性.Visual Studio 2014新特性,并且做了Demo 你知道下一代.NET新变化,还有他们之间的关系吗?@微软中国MSDN @微软中国TechNet @微软中国 微软实战训练营 ! 国内最新的课程!贴近中外名企一线开发! http://54peixun.com/MSTrainingCam

微软 ASP.NET vNext MVC6 Web API3 新特性课程

@老徐FrankXuLei 微软.NET已经开源,下一代.NET有什么新特性?你都知道吗? 今天讲课系统.NET vNext 新特性ASP.NET vNext新特性, MVC6, Web API 3.0新特性,Roslyn编译器 ..NET Native.nGEN.JIT64和RyuJIt新特性.Visual Studio 2014新特性,并且做了Demo 你知道下一代.NET新变化,还有他们之间的关系吗?@微软中国MSDN @微软中国TechNet @微软中国 收起|查看大图|向左转|向右转