博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何收缩日志文件
阅读量:7106 次
发布时间:2019-06-28

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

  数据库的日志文件(*.ldf)越来越大,怎么办?

  收缩吧。收缩日志文件的操作真不简单哟,还跟数据库的恢复模式有关啊。

一、“简单恢复模式”时的日志收缩

1. 截断日志

  当数据库的恢复模式为“简单”的时候,日志文件会在以下情况被截断:

(1)完整备份

(2)遇到检查点(checkpoint)

2. 手动收缩日志文件

  当日志被截断后,日志文件的内部空间就会标记为“可复用”,因此日志文件就不需要持续增长。关于日志文件空间状态的解释,详见  

  手动收缩日志文件的操作可以参考本文稍后的说明。

二、“完整恢复模式”时的日志收缩

  在完整恢复模式下,对数据进行完整备份或者遇到检查点,都不会对日志造成影响。因此,可能会导致日志文件不能被截断,也就是说,这些空间不能被循环使用。于是,日志文件将持续增长,甚至直逼硬盘空间的极限。此时,即使手动收缩日志文件,也不会减小文件空间,因为空间都被占用着。

  注意:“大容量日志恢复模式”与“完整恢复模式”的日志处理方法一致。

1. 确认恢复模式

  以下是使用 SQL Server Management Studio 检查数据库的恢复模式。

2. 完整备份

  日志备份之前,必须做过完整备份。

注意:不要勾选“仅复制备份”选项。“仅复制备份”不会影响日志。

3. 事务日志备份

  做过完整备份之后,可以随时进行事务日志备份。

  默认的选项,是备份后截断事务日志。

注意:有很多情况会阻止日志截断,没有备份事务日志只是其中一种情况,也是最常见的情况。

4. 手动收缩日志文件

  做过日志备份之后,日志被截断,大量空间被标记为“可复用”。一般情况下,这时候就可以进行“收缩文件”操作,以将“可复用”的空间从日志文件中移出,从而减小日志文件。

三、非官方的操作方法

1、临时改用简单恢复模式

  临时改为简单恢复模式,然后做一次完整备份,或者运行checkpoint执行检查点。当日志被截断后,再收缩日志文件,最后再改回完整恢复模式。

  甚至,在简单恢复模式时,可以直接修改日志文件的“初始大小”,改成一个很小的数值即可(系统会自动将日志文件收缩到可能的最小值)。

注意:改回完整恢复模式后,请务必立即做一次完整备份。

2、with no_log选项

  在旧版本里,可以使用 BACKUP LOG WITH NO_LOG,或者 WITH TRUNCATE_ONLY。但是,SQL Server 2008 已经删除了这些选项。

3、分离后再附加

  分离这个数据库,然后删除日志文件。然后重新附加这个数据库,SQL Server 就会警告丢失了日志文件,如果忽略这个警告,系统会自动创建一个空的日志文件。 注意:可能会丢失部分数据,详见《丢失日志文件的风险与对策》

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

你可能感兴趣的文章
蹦极-打破人生惯性
查看>>
微服务架构设计基础之领域驱动设计
查看>>
IntelliJ IDEA编译Android项目比Eclipse慢
查看>>
安易硬盘数据恢复软件v8.81官方版
查看>>
Maven使用图示-关于生命周期、命令行和IDEA插件
查看>>
数据库登录密码不同时,可在文件data ==》config.php修改密码
查看>>
开发人员转型到管理者必须学会的7件事
查看>>
rsync从Windows到Linux的同步备份
查看>>
vmware centos虚拟机配置固定ip
查看>>
检查单 2014-07-15-01
查看>>
Swagger 属性名 FastJson支持
查看>>
eclipse汉化经验
查看>>
CentOS 6.5修改JDK环境
查看>>
求三位数对称素数
查看>>
移动端图片放大滑动查看-插件photoswipe的使用
查看>>
常用DOS命令,程序员的帮手
查看>>
Linux 安装 Apache web服务器
查看>>
struts2 遇到的问题 2
查看>>
Java问答:终极父类(3)
查看>>
彻底搞定Android开发中软键盘的常见问题
查看>>