数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

SQL Server日志文件总结及日志满的处理


发布日期:2024年01月06日
 
SQL Server日志文件总结及日志满的处理

交易日志(Transaction logs)是数据库结构中非常重要但又经常被忽略的部分由于它并不像数据库中的schema那样活跃因此很少有人关注交易日志

交易日志是针对数据库改变所做的记录它可以记录针对数据库的任何操作并将记录结果保存在独立的文件中对于任何每一个交易过程交易日志都有非常全面的记录根据这些记录可以将数据文件恢复成交易前的状态从交易动作开始交易日志就处于记录状态交易过程中对数据库的任何操作都在记录范围直到用户点击提交或后退后才结束记录每个数据库都拥有至少一个交易日志以及一个数据文件

出于性能上的考虑SQL Server将用户的改动存入缓存中这些改变会立即写入交易日志但不会立即写入数据文件交易日志会通过一个标记点来确定某个交易是否已将缓存中的数据写入数据文件当SQL Server重启后它会查看日志中最新的标记点并将这个标记点后面的交易记录抹去因为这些交易记录并没有真正的将缓存中的数据写入数据文件这可以防止那些中断的交易修改数据文件

维护交易日志

因为很多人经常遗忘交易日志因此它也会给系统带来一些问题随着系统的不断运行日志记录的内容会越来越多日志文件的体积也会越来越大最终导致可用磁盘空间不足除非日常工作中经常对日志进行清理否则日志文件最终会侵占分区内的全部可用空间日志的默认配置为不限容量如果以这种配置工作它就会不断膨胀最终也会占据全部可用空间这两种情况都会导致数据库停止工作

对交易日志的日常备份工作可以有效的防止日志文件过分消耗磁盘空间备份过程会将日志中不再需要的部分截除截除的方法是首先把旧记录标记为非活动状态然后将新日志覆盖到旧日志的位置上这样就可以防止交易日志的体积不断膨胀如果无法对日志进行经常性的备份工作最好将数据库设置为简单恢复模式在这种模式下系统会强制交易日志在每次记录标记点时自动进行截除操作以新日志覆盖旧日志

截除过程发生在备份或将旧标记点标为非活动状态时它使得旧的交易记录可以被覆盖但这并不会减少交易日志实际占用的磁盘空间就算不再使用日志它依然会占据一定的空间因此在维护时还需要对交易日志进行压缩压缩交易日志的方法是删除非活动记录从而减少日志文件所占用的物理硬盘空间

通过使用DBCC SHRINKDATABASE语句可以压缩当前数据库的交易日志文件DBCC SHRINKFILE语句用来压缩指定的交易日志文件另外也可以在数据库中激活自动压缩操作当压缩日志时首先会将旧记录标记为非活动状态然后将带有非活动标记的记录彻底删除根据所使用的压缩方式的不同你可能不会立即看到结果在理想情况下压缩工作应该选在系统不是非常繁忙的时段进行否则有可能影响数据库性能

恢复数据库

交易记录备份可以用来将数据库恢复到某一指定状态但交易记录备份本身不足以完成恢复数据库的任务还需要备份的数据文件参与恢复工作恢复数据库时首先进行的是数据文件的恢复工作在整个数据文件恢复完成前不要将其设为完成状态否则交易日志就不会被恢复当数据文件恢复完成系统会通过交易日志的备份将数据库恢复成用户希望的状态如果在数据库最后一次备份后存在多个日志文件的备份备份程序会按照它们建立的时间依次将其恢复

另一种被称为log shipping的过程可以提供更强的数据库备份能力当log shipping配置好后它可以将数据库整个复制到另一台服务器上在这种情况下交易日志也会定期发送到备份服务器上供恢复数据使用这使得服务器一直处于热备份状态当数据发生改变时它也随之更新另一个服务器被称作监视(monitor)服务器可以用来监视按规定时间间隔发送的shipping信号如果在规定时间内没有收到信号监视服务器会将这一事件记录到事件日志这种机制使得log shipping经常成为灾难恢复计划中使用的方案

性能优化

交易日志对数据库有重要作用同时它对系统的整体性能也有一定影响通过几个选项我们可以对交易日志的性能进行优化由于交易日志是一个连续的磁盘写入过程在这当中不会发生读取动作因此将日志文件放在一个独立的磁盘对优化性能有一定作用

另一项优化措施与日志文件的体积有关我们可以设置日志文件的体积不超过硬盘空间的百分之几或者确定它的大小如果将其设置的过大会浪费磁盘空间而如果设置的过小则会强制记录文件不断尝试扩展导致数据库性能下降

事务日志文件Transaction Log File是用来记录数据库更新情况的文件扩展名为ldf

在 SQL Server 和 SQL Server 如果设置了自动增长功能事务日志文件将会自动扩展

一般情况下在能够容纳两次事务日志截断之间发生的最大数量的事务时事务日志的大小是稳定的事务日志截断由检查点或者事务日志备份触发

然而在某些情况下事务日志可能会变得非常大以致用尽空间或变满通常在事务日志文件占尽可用磁盘空间且不能再扩展时您将收到如下错误消息

Error: Severity: State:

The log file for database %*ls is full

除了出现此错误消息之外SQL Server 还可能因为缺少事务日志扩展空间而将数据库标记为 SUSPECT有关如何从此情形中恢复的其他信息请参见 SQL Server 联机帮助中的磁盘空间不足主题

另外事务日志扩展可能导致下列情形

· 非常大的事务日志文件

· 事务可能会失败并可能开始回滚

· 事务可能会用很长时间才能完成

· 可能发生性能问题

· 可能发生阻塞现象

原因

事务日志扩展可能由于以下原因或情形而发生

· 未提交的事务

· 非常大的事务

· 操作DBCC DBREINDEX 和 CREATE INDEX

· 在从事务日志备份还原时

· 客户端应用程序不处理所有结果

· 查询在事务日志完成扩展之前超时您收到假的Log Full错误消息

· 未复制的事务

解决方法

日志文件满而造成SQL数据库无法写入文件时可用两种方法

一种方法清空日志

.打开查询分析器输入命令

DUMP TRANSACTION 数据库名 WITH NO_LOG

再打开企业管理器右键你要压缩的数据库所有任务收缩数据库收缩文件选择日志文件在收缩方式里选择收缩至XXM这里会给出一个允许收缩到的最小M数直接输入这个数确定就可以了

另一种方法有一定的风险性因为SQL SERVER的日志文件不是即时写入数据库主文件的如处理不当会造成数据的损失

: 删除LOG

分离数据库 企业管理器->服务器->数据库->右键->分离数据库

删除LOG文件

附加数据库 企业管理器->服务器->数据库->右键->附加数据库

此法生成新的LOG大小只有多K

注意建议使用第一种方法

如果以后不想要它变大

SQL下使用

在数据库上点右键>属性>选项>故障恢复模型选择简单模型

或用SQL语句

alter database 数据库名 set recovery simple

另外如上图中数据库属性有两个选项与事务日志的增长有关

Truncate log on checkpoint

(此选项用于SQLSQL 中即故障恢复模型选择为简单模型)

当执行CHECKPOINT 命令时如果事务日志文件超过其大小的% 则将其内容清除在开发数据库时时常将此选项设置为True Auto shrink定期对数据库进行检查当数据库文件或日志文件的未用空间超过其大小的%时系统将会自动缩减文件使其未用空间等于% 当文件大小没有超过其建立时的初始大小时不会缩减文件缩减后的文件也必须大于或等于其初始大小对事务日志文件的缩减只有在对其作备份时或将Truncate log on checkpoint 选项设为True 时才能进行

注意一般立成建立的数据库默认属性已设好但碰到意外情况使数据库属性被更改请用户清空日志后检查数据库的以上属性以防事务日志再次充满

上一篇:SQL入门:运算次序

下一篇:PL/SQL命名作用域的窍门