博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server误区30日谈-Day14-清除日志后会将相关的LSN填零初始化
阅读量:7124 次
发布时间:2019-06-28

本文共 1795 字,大约阅读时间需要 5 分钟。

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

 

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

错误

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

    你可以在我的博客中看到有关日志文件填零初始化的博文:。以及我发布在TechNet杂志的文章:。

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

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

 

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

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

 

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

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

   

转载地址:http://echel.baihongyu.com/

你可能感兴趣的文章
android 通知(android 8.0可用)
查看>>
Android 系统设置中显示设置之休眠和屏保设置篇
查看>>
POJ 1741 Tree (点分治)
查看>>
POJ 3660 Cow Contest (dfs)
查看>>
ASP.NET Core MVC I/O编程模型
查看>>
Android收起虚拟键盘
查看>>
基于二分查找(折半查找)的时间范围匹配
查看>>
PYTHON1.day10
查看>>
Android性能优化篇 [ 谷歌官方 ]
查看>>
ThinkPHP/---获取今天开始的时间戳与结束的时间戳
查看>>
matlib常用知识
查看>>
Directx11教程(43) 纹理映射(13)-动态纹理映射
查看>>
opengl 教程(13) 摄像机坐标系
查看>>
[leetcode-526-Beautiful Arrangement]
查看>>
yii CGridView colum 链接
查看>>
windows 如何将安装Anaconda之前已经安装的python版本(中已安装的库)移动到 Anaconda中...
查看>>
【OCP-12c】2019年CUUG OCP 071考试题库(79题)
查看>>
Centos 7.0 Linux - 给普通用户加sudo权限
查看>>
load data infile出现“ERROR 13 (HY000): Can't get stat of '/tmp/test2.txt' (Errcode: 2)”问题
查看>>
主席树的学习
查看>>