首页 游戏 软件 资讯 排行榜 专题
首页
科技数码
SQL Server事务日志无法收缩?4步排查与解决实战案例

SQL Server事务日志无法收缩?4步排查与解决实战案例

热心网友
55
转载
2026-02-04

数据库日志管理是DBA日常工作中相当重要的一环。与其等到日志文件撑爆磁盘再手忙脚乱地处理,不如提前建立起规范的监控和维护流程,从源头上把问题解决掉。

一大早,开发团队就反映监控系统告警,数据库db1的日志文件已经把磁盘占满了。这已经是个老生常谈的问题,通常的解决办法就是执行一波日志收缩操作。但这一次,常规手段居然失灵了!

1. 问题重现:常规操作不灵了

我们通常会执行下面的命令来收缩事务日志:

ALTER DATABASE [db1] SET RECOVERY SIMPLE;
DBCC SHRINKFILE (N‘db1_log‘, 1024);
ALTER DATABASE [db1] SET RECOVERY FULL;

可这次执行之后,日志文件的大小纹丝不动。作为一名经验丰富的DBA,我立刻意识到事情恐怕没那么简单。

2. 排查过程:揪出“罪魁祸首”

面对这种情况,我首先检查了日志文件无法被重用的原因:

SELECT name, log_reuse_wait_desc FROM sys.databases WHERE name = ’db1’;

查询结果显示,log_reuse_wait_desc字段的值是“REPLICATION”。这就有点奇怪了,因为我清楚这个数据库并没有配置任何复制功能。查阅资料后才发现,这很可能是之前残留的、未清理干净的复制元数据在作祟。

我接着确认一下当前活动事务的情况:

DBCC OPENTRAN(’db1’);

果然,存在活动事务阻塞了日志的截断。

3. 解决方案:多管齐下

针对发现的这些问题,我采取了以下组合措施:

(1) 清理复制元数据

EXEC sp_removedbreplication ’db1’;

这个命令会清除数据库里的复制信息。但请注意:如果数据库确实需要用到复制功能,就不能使用这个方法,否则会破坏现有复制架构。

(2) 处理活动事务

通过 DBCC OPENTRAN 找到活动事务后,我与开发团队进行了确认,终结了那些长时间运行且不再必要的事务。

如果是分布式事务或者涉及了数据库链接的情况,很可能导致事务一直处于需要手动回滚的状态,并且基本不会自动完成(别问我是怎么知道的,都是教训)。这时候就需要考虑在业务低峰期或维护窗口重启数据库实例了。

(3) 日志备份后截断

对于采用完整恢复模式的数据库,进行日志备份才是截断日志的正确姿势:

-- 执行日志备份
BACKUP LOG [db1] TO DISK = N’D:\Backup\db1_Log.bak’;
-- 然后再收缩
DBCC SHRINKFILE (N’db1_log‘, 1024);

如果确定不需要保留日志备份,也可以临时切换到简单恢复模式来截断日志:

-- 将数据库恢复模式改为simple
ALTER DATABASE [db1] SET RECOVERY SIMPLE;
-- 截断并收缩日志文件
DBCC SHRINKFILE (N’db1_log‘, 1024);
-- 恢复数据库的完整恢复模式
ALTER DATABASE [db1] SET RECOVERY FULL;

用这种方式截断日志后,建议紧接着做一次完整的数据库备份。

之后可以查看一下各个文件的大小情况:

-- 查看所有数据文件和日志文件的大小及路径
SELECT DB_NAME(database_id) AS 数据库名,
       name AS 逻辑文件名,
       type_desc,
       physical_name,
       size * 8.0 / 1024 AS 文件大小_MB,
       CASE WHEN type_desc = ’ROWS‘ THEN FILEPROPERTY(name, ’SpaceUsed‘) * 8.0 / 1024
            ELSE NULL END AS 已用空间_MB,
       CASE WHEN type_desc = ’ROWS‘ THEN (size * 8.0 / 1024) - (FILEPROPERTY(name, ’SpaceUsed‘) * 8.0 / 1024)
            ELSE NULL END AS 剩余空间_MB
FROM sys.master_files;

(4) 预防措施:建立长效机制

问题解决后,我制定了以下预防措施,避免问题卷土重来:建立定期的日志备份计划,避免日志无限增长;监控长时间运行的事务,设置告警机制;定期检查日志文件大小,防患于未然。

4. 总结

通过这次排查,我总结出日志文件无法收缩的几种常见原因及应对策略:活动事务阻塞:使用 DBCC OPENTRAN 检查并处理。复制问题:清理复制元数据或重新配置复制。缺少日志备份:在完整恢复模式下,必须定期备份日志。其他因素:如数据库镜像、快照创建等,需针对性处理。

数据库日志管理是DBA日常工作中相当重要的一环。与其等到日志文件撑爆磁盘再手忙脚乱地处理,不如提前建立起规范的监控和维护流程,从源头上把问题解决掉。

希望这次的实战经验对大家有所帮助!如果你有更好的解决办法或独特见解,欢迎与我交流探讨。

来源:https://www.51cto.com/article/834027.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

上海启动全球首颗光计算卫星研制 提升太空算力布局
科技数码
上海启动全球首颗光计算卫星研制 提升太空算力布局

上海启动全球首颗光计算卫星研制,其天基光计算具备抗辐照、低功耗特性,适应太空环境,可支撑在轨大算力任务。目前芯片太空验证已完成,全链条研制能力基本形成。产业面临成本与规模化挑战,需重构航天制造体系。长三角已成立创新联合体聚焦七大技术攻坚,上海将天基计算列为未来。

热心网友
05.19
百度成立AI模型委员会强化技术优势 苹果与OpenAI合作现裂痕
科技数码
百度成立AI模型委员会强化技术优势 苹果与OpenAI合作现裂痕

苹果与OpenAI合作因商业回报未达预期出现裂痕。腾讯地图推出AI骑手模式优化配送。百度成立模型委员会强化AI布局。荣耀将发布搭载云台系统的RobotPhone。Anthropic拟以9000亿美元估值融资。阿里发布智能体开发工作台Qoder1 0。千问APP接入药监局数据。发那科与英伟达深化合作,利用AI加速机器人开发。

热心网友
05.19
图书管理软件有哪些实用推荐与使用心得分享
游戏资讯
图书管理软件有哪些实用推荐与使用心得分享

面对海量书籍资源,数字化管理工具至关重要。小满图书管理侧重会员与库存管理,适合书店。库存管理通轻量化,支持多货品进销存。藏书馆兼具藏书管理与数字阅读功能。移动图书馆对接高校资源,提供学术服务。个人图书馆专注个人知识收集与创作。各类软件功能各异,需根据核心需求选择。

热心网友
05.19
流畅好用的英文朗读软件推荐
游戏资讯
流畅好用的英文朗读软件推荐

英文朗读软件能有效辅助学习。推荐几款特色应用:全能型《朗读器》操作简便;《朗读者》结合翻译与朗读;《英文翻译》支持长文朗读;《朗读大师》擅长图像识别与发音反馈;《中英文翻译》提供系统化学习路径。根据需求选择工具并坚持练习,可提升理解与发音能力。

热心网友
05.19
飞机票购买软件推荐 这几款订机票APP实用又划算
游戏资讯
飞机票购买软件推荐 这几款订机票APP实用又划算

飞机是远距离出行的高效选择,提前购票可锁定行程并享受优惠。主流购票平台包括飞猪旅行、携程旅行、航班管家、美团、飞行卡和去哪儿旅行。这些应用不仅提供机票预订,还整合酒店、景点门票、本地生活等服务,满足用户对价格、一站式规划或特定优惠的不同需求。

热心网友
05.19