0

0

Linux btrfs scrub / balance 的定期维护计划与 IO 影响控制

舞夢輝影

舞夢輝影

发布时间:2026-02-16 08:16:03

|

313人浏览过

|

来源于php中文网

原创

scrub 不会卡死系统但会打满磁盘io,需用 ionice -c2 -n7 限速;balance 仅在 chunk 碎片、分布不均或设备故障时才需运行;scrub 与 balance 必须串行且先 scrub 后 balance。

linux btrfs scrub / balance 的定期维护计划与 io 影响控制

scrub 会卡住系统吗?IO 负载怎么压下来

不会直接卡死,但默认跑法会让磁盘 IO 持续打满,尤其在机械盘或混用负载的机器上,rsyncpostgres 这类服务响应会明显变慢。

关键不是“做不做”,而是“怎么限速”。btrfs scrub 本身不支持 --throttle 或类似参数,得靠外部工具控速:

  • ionice -c2 -n7 降低 IO 调度优先级(推荐,对交互影响最小)
  • 配合 cpulimit 没用——scrub 是 IO 密集型,CPU 占用通常不到 5%
  • 避免在 /proc/sys/vm/swappiness 高的机器上跑,swap 活跃时 scrub 可能触发内存回收抖动

示例命令:

ionice -c2 -n7 btrfs scrub start -B /mnt/data
-B 表示前台运行,方便配合 ionice

balance 什么时候必须跑?哪些 filter 真的有用

不是定期跑就有益。btrfs balance 主要解决两类问题:碎片导致的写放大、chunk 分布不均引发的单盘过载。80% 的误操作源于把它当“磁盘整理”用。

真正需要 balance 的信号只有三个:

  • btrfs filesystem usage /path 显示某块 device 的 used 接近 100%,但其他盘还有空闲
  • 写入大量小文件后,btrfs filesystem df /pathData 类型的 total 远大于 used(说明 chunk 碎片严重)
  • 执行 btrfs device stats /path 发现某设备有持续 read_failures,balance 可强制迁移该设备上的 chunk(但先确认硬件没坏)

常用 filter 中,usage=85profiles=dup 最实用;limit=100 这种纯数字限制容易误伤——它按 chunk 数计,不是按空间算。

Synthesia
Synthesia

Synthesia是一个AI视频生成平台,可以让用户创建120种语言的视频。

下载

scrub 和 balance 能不能一起跑?顺序有讲究吗

绝对不要并发执行。两者都会读写 chunk tree 和 extent tree,同时跑大概率触发 transaction aborted 错误,日志里出现 aborting transaction 就是这个原因。

必须串行,且顺序固定:

  • btrfs scrub —— 它只读,能发现静默数据损坏,是 balance 前的安全检查
  • 等 scrub 完成且无 errors(查 btrfs scrub status /path),再跑 btrfs balance
  • balance 完了最好再 scrub 一次,验证迁移后的数据一致性

中间任意一步失败,就停住。balance 半途被 kill 可能留下 inconsistent chunk tree,恢复起来比重做还麻烦。

crontab 里怎么写才不算耍流氓

直接写 0 2 * * 0 btrfs scrub start /mnt/data 是典型反模式:没检查挂载状态、没处理锁冲突、没防 overlap。

一个可用的最小化脚本逻辑:

  • findmnt -T /mnt/data 确认路径已挂载且是 btrfs
  • 检查 /var/run/btrfs-scrub.lock 是否存在(自己建个简单锁文件)
  • timeout 24h 防止 scrub 卡死(某些坏块场景下会 hang 住)
  • 把输出重定向到 /var/log/btrfs-scrub.log,别丢进 /dev/null

IO 影响最隐蔽的点:balance 默认使用 metadatasystem profile 的 full write,即使你只 filter data chunk,它仍会重写所有 metadata。这意味着 SSD 的写入放大和寿命消耗比看起来高得多。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1520

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

714

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

791

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

584

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

560

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

307

2023.07.20

linux查看cpu使用率
linux查看cpu使用率

在linux的系统维护中,可能需要经常查看cpu使用率,分析系统整体的运行情况。本专题为大家带来了linux查看cpu使用率的相关文章,感兴趣的朋友千万不要错过了。

394

2023.07.25

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.1万人学习

Git 教程
Git 教程

共21课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号