数据库日志无法收缩

原创 2017年09月14日 22:14:28

前言


在论坛里面经常有人遇到,数据库日志文件无法收缩的问题。这里详细介绍下这个问题怎么解决。


处理


遇到日志文件无法收缩的问题,第一步肯定是先运行下面的命令:

SELECT name,log_reuse_wait_desc FROM sys.databases where name='dbname'



对应的log_reuse_wait_desc 说明如下图:


图中标红的几个是最常见的几种类型

对应LOG_BACKUP    ,先对数据库做个日志备份,或者 把数据库变成简单模式。然后再试着压缩数据库。

ACTIVE_TRANSACTION,使用 DBCC OPENTRAN (dbname) 检查数据库中是不是有开启未提交的事务,如果有就kill掉

对应REPLICATION ,很可能是因为数据库搭建了复制或者是曾经搭建了复制,没有清除干净。运行下面的命令彻底清除复制信息

exec sp_removedbreplication 'database'

另外,补充下,显示REPLICATION还有一种隐藏的原因,可能的因为数据库开启了CDC。因为他们都是使用的LOG READER。


总结

按照上面的操作步骤就可以解决几乎所有数据库日志无法收缩的问题。如果有遇到,用什么的办法还无法解决的案例,欢迎在评论中留言。


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

性能调优系列文章目录

前言 之前写了很多文章都是想到什么,或者最近遇到什么实际案例就写相关的实战场景。 比如: Trim的优化 ,Sleeping会话造成的阻塞 我决定,整理一个性能调优文章列一个大纲,争取在一个月之内写...

TempDB暴涨问题排查

tempdb日志文件暴增 ,造成磁盘空间不足,甚至影响业务运行。如何找到产生问题的元凶,加以解决避免以后再次发生。...

sql server 2005数据库日志无法收缩

 数据库出问题的过程:数据库体积很大,分两个文件,共40多G,没有启动完整日志,用的是简单日志。经过几次非法关机重启,数据库状态被标为可疑,无法使用。为了尽量减少损失,没有采取还原备份的方式,想办法恢...
  • tftutu
  • tftutu
  • 2011年06月19日 15:58
  • 1127

收缩数据库日志文件

  • 2013年07月08日 15:50
  • 21KB
  • 下载

sqlserverlog数据库日志收缩

  • 2014年03月13日 18:27
  • 253KB
  • 下载

数据库文件及日志收缩

sql server2000,2005 收缩数据库,收缩日志,压缩数据库文件大小,截断日志,收缩日志...

sql server 2008 数据库日志收缩

  • 2013年07月17日 09:03
  • 518B
  • 下载

收缩数据库日志信息

  • 2013年11月20日 17:38
  • 394B
  • 下载

DBCC大全集之(适用版本MS SQLServer 2008 R2)----DBCC SHRINKFILE收缩当前数据库的指定数据或日志文件的大小

收缩当前数据库的指定数据或日志文件的大小,或通过将数据从指定的文件移动到相同文件组中的其他文件来清空文件,以允许从数据库中删除该文件。文件大小可以收缩到比创建该文件时所指定的大小更小。这样会将最小文件...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据库日志无法收缩
举报原因:
原因补充:

(最多只允许输入30个字)