• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SQL Server误区30日谈 第14天 清除日志后会将相关的LSN填零初始化

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

    错误

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

        你可以在我的博客中看到有关日志文件填零初始化的博文:Search Engine QA #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

    相应的,在日志中你可以看到:
    复制代码 代码如下:

    2010-04-13 13:20:27.55 spid53 DBCC TRACEON 3004, server process ID (SPID) 53. This is an informational message only; no user action is required.
    2010-04-13 13:20:27.55 spid53 DBCC TRACEON 3605, server process ID (SPID) 53. This is an informational message only; no user action is required.
    2010-04-13 13:20:27.63 spid53 Zeroing D:\SQLskills\LogClearTest_log.ldf from page 0 to 2560 (0x0 to 0x1400000)
    2010-04-13 13:20:28.01 spid53 Zeroing completed on D:\SQLskills\LogClearTest_log.ldf
    2010-04-13 13:20:28.11 spid53 Starting up database 'LogClearTest'.
    2010-04-13 13:20:28.12 spid53 FixupLogTail() zeroing D:\SQLskills\LogClearTest_log.ldf from 0x5000 to 0x6000.
    2010-04-13 13:20:28.12 spid53 Zeroing D:\SQLskills\LogClearTest_log.ldf from page 3 to 63 (0x6000 to 0x7e000)
    2010-04-13 13:20:28.14 spid53 Zeroing completed on D:\SQLskills\LogClearTest_log.ldf
    2010-04-13 13:20:28.16 spid53 Setting database option RECOVERY to SIMPLE for database LogClearTest.
    2010-04-13 13:20:29.49 spid53 Setting database option RECOVERY to SIMPLE for database LogClearTest.


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

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

       

    您可能感兴趣的文章:
    • SQL Server误区30日谈 第29天 有关堆碎片的误区
    • SQL Server误区30日谈 第28天 有关大容量事务日志恢复模式的误区
    • SQL Server误区30日谈 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB
    • SQL Server误区30日谈 第26天 SQL Server中存在真正的“事务嵌套”
    • SQL Server误区30日谈 第25天 有关填充因子的误区
    • SQL Server误区30日谈 第24天 26个有关还原(Restore)的误区
    • SQL Server误区30日谈 第23天 有关锁升级的误区
    • SQL Server误区30日谈 第22天 资源调控器可以调控IO
    • SQL Server误区30日谈 第21天 数据损坏可以通过重启SQL Server来修复
    • SQL Server误区30日谈 第20天 破坏日志备份链之后,需要一个完整备份来重新开始日志链
    • SQL Server误区30日谈 第19天 Truncate表的操作不会被记录到日志
    • SQL Server误区30日谈 第18天 有关FileStream的存储,垃圾回收以及其它
    • SQL Server误区30日谈 第17天 有关页校验和的误区
    • SQL Server误区30日谈 第16天 数据的损坏和修复
    • SQL Server误区30日谈 第15天 CheckPoint只会将已提交的事务写入磁盘
    • SQL Server误区30日谈 第13天 在SQL Server 2000兼容模式下不能使用DMV
    • SQL Server误区30日谈 第12天 TempDB的文件数和需要和CPU数目保持一致
    • SQL Server误区30日谈 第11天 镜像在检测到故障后瞬间就能故障转移
    • SQL Server误区30日谈 第10天 数据库镜像在故障发生后 马上就能发现
    • SQL Server误区30日谈 第9天 数据库文件收缩不会影响性能
    • SQL Server误区30日谈 第8天 有关对索引进行在线操作的误区
    • SQL Server误区30日谈 第7天 一个实例多个镜像和日志传送延迟
    • SQL Server误区30日谈 第6天 有关NULL位图的三个误区
    • SQL Server误区30日谈 第5天 AWE在64位SQL SERVER中必须开启
    • SQL Server误区30日谈 第4天 DDL触发器就是INSTEAD OF触发器
    • SQL Server误区30日谈 第3天 即时文件初始化特性可以在SQL Server中开启和关闭
    • SQL Server误区30日谈 第2天 DBCC CHECKDB会导致阻塞
    • SQL Server误区30日谈 第1天 正在运行的事务在服务器故障转移后继续执行
    • SQL Server误区30日谈 第30天 有关备份的30个误区
    上一篇:SQL Server误区30日谈 第13天 在SQL Server 2000兼容模式下不能使用DMV
    下一篇:SQL Server误区30日谈 第15天 CheckPoint只会将已提交的事务写入磁盘
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQL Server误区30日谈 第14天 清除日志后会将相关的LSN填零初始化 SQL,Server,误区,30日谈,第,