热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

探查SQLServer虚拟日志文件

SQLServer把事务日志文件划分为多个VLF(VirtualLogFile),即虚拟日志文件。一、VLF的4种状态1、active。表示VLF中存在活动的事务(即未完成的事务)。2、recov

SQLServer把事务日志文件划分为多个VLF(VirtualLogFile),即虚拟日志文件。一、VLF的4种状态1、active。表示VLF中存在活动的事务(即未完成的事务)。2、recov

SQL Server 把事务日志文件划分为多个VLF(Virtual Log File),即虚拟日志文件。

一、VLF的4种状态

1、active。表示VLF中存在活动的事务(即未完成的事务)。

2、recoverable。表示VLF中的事务全部已经完成,但是某些操作(例如数据库镜像、复制等)还需要用到这些数据,因此不可以被覆盖。

3、reusable。表示VLF中的数据已经不需要了,可以被覆盖。

4、unused。表示VLF从未被使用。

二、简单恢复模式时的VLF

1、文件的初始状态

  测试数据库名为db01,网站空间,恢复模式设为简单。mdf与ldf文件初始状态如下:

2、填充数据

  运行以下脚本,填充大量数据:

create table testtable (UserID varchar(100),pwd varchar(200))
declare @i int
declare @d1 datetime
set @i=0
-- truncate TABLE [testtable]
insert into testtable select 'a','b'
while @i<18
begin
set @d1 = getdate()
insert into [testtable]
select UserID+cast(floor(rand()*1000) as nvarchar(50)),
cast(floor(rand()*100000) as nvarchar(50))+UserID+cast(floor(rand()*100) as nvarchar(50))
from [testtable]
set @i=@i+1
-- print '第' + Cast(@i as varchar(50)) + '圈,用时:' + Cast(datediff(ms,@d1,getdate()) as varchar(50)) + 'ms'
end

3、检查磁盘增长

  运行脚本后,LDF文件由最初的1MB增长到53MB。

  打开“报表”--“标准报表”--“磁盘使用情况”。

4、检查VLF

  执行dbcc loginfo,检查VLF使用情况。

  上表中的FileID=2表示数据库的第2个文件,对于db01这个测试库,第2个文件就是唯一的LDF文件。FileSize表示VLF的大小。FSeqNo表示VLF的序列号,如果为零则表示这个VLF未被使用。CreateLSN为零,表示创建数据库时就同时创建了这些VLF;不为零则表示在LSN产生时才创建这个VLF。

  Status列表示VLF的状态,如果为0则表示这个VLF为reusable或者unused,如果为2则表示这个VLF为active或者recoverable。

  可以通过sys.databases 系统视图查看事务日志不能被截断的原因。例如:

select log_reuse_wait , log_reuse_wait_desc from sys.databases where

5、查看VLF中的LSN

  通过dbcc loginfo,可以查到Status=2的最小的FSeqNo=1865,服务器空间,那么可以通过以下语句查询这个VLF中的LSN。

select * from ::fn_dblog(1865000000000000001 ,1866000000000000000 )

  上图第1列显示的16进制LSN不能直接使用,需要换算成正常的10进制LSN。以第一行为例,第1段为VLF序列号,749H换算成10进制为1865;第2段为日志区块的第1个扇区编号,6EH换算成10个字符的10进制为0000000110;第3段为该扇区内的流水号,1H换算成4个字符的10进制为0001。因此,正常的LSN为186500000001100001。

6、checkpoint的影响

  从上表可以看出,存在一些Status=2的VLF。如果数据缓冲区仍有一些“脏数据”未回写到mdf文件,可执行checkpoint,使“脏数据”立即进行回写。(前面的例子中,从sys.databases 系统视图可以看到有一个事务还未完成,导致checkpoint延迟)

  说明:在生产环境中,美国服务器,即使在简单恢复模式,如果有个事务很早就Begin Transaction,而忘记被Commit/Rollback,结果可能看到一个很大的日志文件。

  再执行dbcc loginfo,检查VLF使用情况。可见绝大多数的VLF已经Status=0。

  再检查“磁盘使用情况”。

7、收缩日志文件

  在简单恢复模式时,自动或手动checkpoint操作,以及对数据库做完全备份都会将recoverable状态的VLF标记成Status=0,这些VLF可以被不断重用。如果没有大量的事务导致checkpoint延迟或者“脏数据”回写延迟,LDF文件就不需要增长。

  收缩日志文件时,数据库引擎会检查VLF的状态,将Status=0(即reusable和unused)的VLF所占用的空间释放出来,然后LDF再收缩它的边界。

三、完整恢复模式时的VLF

  在完整恢复模式时,事务日志需要单独备份,因此checkpoint会被延迟,导致recoverable状态的VLF不能被标记成reusable状态。由于这些VLF不能被重用,导致LDF文件持续增长。

  执行事务日志备份后,VLF的状态被标记为Status=0,才可以被重用。

  为了避免LDF过度增长,应当增加事务日志备份的频率。

四、参考资料

1、《事务日志 (SQL Server)》

2、《数据库检查点 (SQL Server)》

3、《简介数据库日志文件的增长》

本文出自 “JimShu (MCITP/MCSE/MCT)” 博客,请务必保留此出处

推荐阅读
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
author-avatar
simona2006_827
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有