技术解析

断电后 ubuntu 文件系统损坏?
0
2021-06-28 08:27:32
idczone

背景

我这边有一些设备,每天都要强制断电,有的时候就会出现无法进入系统的情况。

解决方案选择

  1. 预防
  2. 解决

问题

  1. 如果是预防的话,方案是将系统设置为只读,领导提供的方案是 Overlayroot,我没接触过,网上也没找到什么例子,有大神接触过的请不吝赐教,拜谢!
  2. 如果是解决的话,看了一下,用 fsck 应该是可以的,但是领导说系统都崩了,根本找不到 fsck 命令的,但我有点疑问,如果 fsck 是在系统启动之后才能运行的话,那设置/etc/default/rcS下的FSCKFIX = yes有什么用呢?

附加

不考虑 ups,设备多,成本太高


btrfs 你值得拥有

我给你出个馊注意吧,借鉴嵌入式系统,用 ramfs, cramfs, squashfs 等只读文件系统,数据挂 ext4, xfs 日志文件系统。

如果能改接受系统重启后数据还原就直接使用 aufs 弄成类似 LiveCD 那种格式。

不能提前关机么?

以前用过 ubuntu 11.04 每次机房断电,恢复供电后启动系统,这时看到各个分区都变为只读挂载了。
难道只读这个过程不是自动的?

万年 ext4,断电也没坏过。btrfs 千万别用

不能 [手动捂脸] ,时间不定 0.0

我手上一块开发板现在当家庭 server 也是,每次都起不来,每次都得手动取卡执行 fsck,其实是我懒,只要配置好 initramfs,在 initramfs 阶段中完成 fsck 就没这些问题了,但配置方法我弄丢了(主要是 ubbot 启动脚本),想着反正一年就几次而已就没管。
或者像嵌入式系统那样,原始的 rootfs 分区挂载为只读,然后数据分区挂载读写,最后挂载 OverlayFS 做为真正的 /

Linux 这种需求不为过,可以满足,但是如果想做到安全,需要定制。
另外,应用内存数据不考虑保护吗?

我的软路由刷 LEDE 也是这个问题, 掉电后重新启动就是只读挂载, 搜了一下应该是 linux 常见的问题

断电之前先关机,

表示我的树莓派也是这样,目前解决方案是常年接个充电宝。。。

经常断电,力荐 xfs
硬盘足够多,那么数据盘使用带冗余策略的 ZFS 也是很好的选择
btrfs ... 那玩意还是算了吧

求充电宝型号?一直找不到满足要求的:1.能边放边充。2.断电时供电不会短时断开

每天强制断电是什么场景

禁用硬盘自带缓存


https://www.v2ex.com/t/184485

我也在找,tb 上有些宿舍路由器 ups,不知道常通电会不会有安全隐患

上学时候,宿舍 23:30 准时断电... 那时我用 freebsd 6 和 debian,crontab 设置了 23:25 自动关机,然后就听着楼道里各种咒骂断电的例行吐槽。

买个 ups 护着?起码有时间关机。

支持楼上 ups,强制断电也会损耗电脑,还不如先关机别老想者用复杂的办法

损耗哪个部件?

客户那边的需求 0.0 而且断电时间不定

嗯,这方面也在考虑,但性能会受到一定的影响

对啊,现在就发愁呢,只能在内存里少放数据

Overlayroot 方案不错

嗯,看了一下,不难配置,就是更改系统设置的时候得从 grub 重新引导比较烦,有什么经验传授一下么大神

但是仍然有问题需要处理。数据分区也可能断电损坏

那就 overlayroot+开机自动 fsck ?

极域可以联动关机,仅供参考

之前家里的上网本当 server 也遇到这个问题,不过好在有电池,于是写了个脚本,发现断电并且电量不够了自动关机,2333

我这要有电池就没问题了 233

问题 2:开机时调用的 e2fsck 是在 内存闪存盘 /内存文件系统 中的,并不是系统根文件系统中的那个
系统启动前,会在内存中创建一个内存闪存盘或内存文件系统,内部解压进去一个最小的文件系统(由 busybox,启动脚本和一些必要的工具,例如 e2fsck )。
因此只要保证这个镜像(例如 /boot/initrd-xxxxx.img )可以就可以在开机之前检查文件系统

1,可以尝试把 /分区 remount 挂载成只读,应用需要迁移到单独分区,而且应用还要支持 recovery 等特性。(补充下:内核启动参数默认就是 ro 的,systemd 会 remount / 为 rw )。
2,fsck 修复文件系统,如果断电的时候正在写文件,该文件可能会已经损坏了,fsck 也许能修复改文件。
btrfs 推荐使用分区如下:/rw_root_fs 这是原系统根文件系统 ,/ro_root_fs 这是只读的 rw_root_fs 的 snapshot 子卷 ,/usr/local/ 或者 /otp 这是应用分区 ;从 ro_root_fs 只读启动或者启动后 remount 成只读。btrfs 理论上不需要 fsck。

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服