即使日志文件有 99% 的可用空间,SQL 也不会收缩日志文件,并会出现“所有逻辑日志文件都在使用中”错误

即使日志文件有 99% 的可用空间,SQL 也不会收缩日志文件,并会出现“所有逻辑日志文件都在使用中”错误

我有一个日志文件,它已经增长到 32GB 并占满了我的硬盘。因此,我进行了事务日志备份,现在当我执行“DBCC SQLPERF ( LOGSPACE )”时,它显示我的日志文件的 99% 都是空白空间,这很好:

DBCC SQLPERF ( LOGSPACE )
Database Name   Log Size (MB)   Log Space Used (%)  Status
abc             32140.02        0.3069714       0

现在我想缩小文件大小(它应该只有几兆!),所以我这样做:

DBCC SHRINKFILE ( abc_log )

在 SSMS 中的查询结果中,我得到以下内容:

Results tab:
DbId    FileId  CurrentSize MinimumSize UsedPages   EstimatedPages
14  2   4113923 128 4113920 128

在“消息”选项卡中,有以下这条信息:

Cannot shrink log file 2 (abc_log) because all logical log files are in use.
(1 row(s) affected)
DBCC execution completed. If DBCC printed error messages, contact your system administrator.

这是怎么回事?

答案1

等待一个安静的时间并进行事务日志备份,然后立即进行收缩。

答案2

您没有提到您的 SQL Server 版本。根据“SQL Server 内部”, “(在 7.0 中)... 物理收缩只能从日志末尾进行,活动部分永远无法收缩。为了解决这种情况,您必须在截断日志后输入一些虚拟事务,以强制日志的活动部分移动到文件的开头”。更高版本应该会为您做到这一点。

半小时后缩小可能只是自动缩小(您刚刚打开该选项吗?)开始起作用。它每 30 分钟缩小一次。

答案3

我是一个糟糕的 SQL 管理员,通常只是将数据库更改为简单恢复模式,收缩,然后将其改回完整模式。我猜这在你依赖完整模式进行镜像的情况下不会起作用。

答案4

我确实有我的网站中的程序就是这样的。

无论何时我都需要。

相关内容