SQL Server误区30日谈-Day14-清除日志后会将相关的LSN填零初始化

本文深入探讨了SQL Server日志文件在手动增长、自动增长和创建时进行填零初始化的过程,澄清了日志清除与日志截断的概念区别,通过测试代码展示了SQL Server对日志文件进行填零初始化的具体步骤,以及如何通过DBCC SQLPERF追踪标记来观察这一过程。同时,提供了SQL Server日志文件填零初始化的相关博文链接和理解日志与恢复过程的文章链接。

    本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVERYTHING!!,经过我们团队的翻译和整理发布在AgileSharp上。希望对大家有所帮助。

 

误区 #14.清除日志后会将相关的LSN填零初始化

错误

    当日志文件在手动增长,自动增长和创建时都会进行填零初始化操作。但是请不要把这个过程和定期清除日志的过程搞混。日志截断仅仅意味着将一个或多个VLF标记为不活动以便被重复使用。在日志清除的过程中,并没有任何日志被清除或是填0。“清除日志”和”截断日志”意思是一样的,但都属于用词不当,因为在这个过程中日志的大小不会有任何改变。

    你可以在我的博客中看到有关日志文件填零初始化的博文:Search Engine Q&A #24: Why can't the transaction log use instant initialization?。以及我发布在TechNet杂志的文章:Understanding Logging and Recovery in SQL Server

    你可以通过跟踪标记3004来查看SQL Server对日志文件进行填零初始化的过程。将这个追踪标记打开当日志文件增长时,你就可以在SQL Server日志中看到相关信息,下面是测试代码:


 

  

  
DBCC TRACEON (3004, 3605); GO
-- Create database and put in SIMPLE recovery model so the log will clear on 
checkpoint CREATE DATABASE LogClearTest ON PRIMARY ( NAME = 
'LogClearTest_data', FILENAME = N'D:\SQLskills\LogClearTest_data.mdf') 
LOG ON ( NAME = 'LogClearTest_log', FILENAME = 
N'D:\SQLskills\LogClearTest_log.ldf', SIZE = 20MB); GO
-- Error log mark 1 ALTER DATABASE LogClearTest SET RECOVERY SIMPLE; 
GO
USE LogClearTest; GO
-- Create table and fill with 10MB - so 10MB in the log CREATE TABLE t1 
(c1 INT IDENTITY, c2 CHAR (8000) DEFAULT 'a'); GO INSERT INTO t1 DEFAULT 
VALUES; GO 1280
-- Clear the log CHECKPOINT; GO
-- Error log mark 2 ALTER DATABASE LogClearTest SET RECOVERY SIMPLE; 
GO


 

    相应的,在日志中你可以看到:

DBCC TRACEON (3004, 3605); GO
-- Create database and put in SIMPLE recovery model so the log will clear on 
checkpoint CREATE DATABASE LogClearTest ON PRIMARY ( NAME = 
'LogClearTest_data', FILENAME = N'D:\SQLskills\LogClearTest_data.mdf') 
LOG ON ( NAME = 'LogClearTest_log', FILENAME = 
N'D:\SQLskills\LogClearTest_log.ldf', SIZE = 20MB); GO
-- Error log mark 1 ALTER DATABASE LogClearTest SET RECOVERY SIMPLE; 
GO
USE LogClearTest; GO
-- Create table and fill with 10MB - so 10MB in the log CREATE TABLE t1 
(c1 INT IDENTITY, c2 CHAR (8000) DEFAULT 'a'); GO INSERT INTO t1 DEFAULT 
VALUES; GO 1280
-- Clear the log CHECKPOINT; GO
-- Error log mark 2 ALTER DATABASE LogClearTest SET RECOVERY SIMPLE; 
GO

 

    上面测试代码中ALTER DATABASE是作为日志中这部分的开始和结束标记。在两个Alter Database命令中的CheckPoint并不会引起填0操作。如果你需要进一步验证这点,在Checkpoint之前和之后分别使用DBCC SQLPERF (LOGSPACE)来查看日志文件的大小,你会发现虽然日志文件大小没有变,但是日志的使用空间百分比会大大减少。

   (下图是译者测试的结果):

    2012-10-16_131854

转载于:https://www.cnblogs.com/CareySon/archive/2012/12/24/2831215.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值