Linux|Linux Kernel 5.12-RC1标记为dontuse 严重到会毁掉整个根文件系统
【Linux|Linux Kernel 5.12-RC1标记为dontuse 严重到会毁掉整个根文件系统】在昨天发布的 Linux 内核邮件列表中 , 大神 Linus Torvalds 在他的公共 Git Tree 中警告全世界不要使用 5.12-rc1 内核 。邮件中写道:“某些人可能已经注意到在我的公共 GitTree 中 , ‘v5.12-rc1’已经被标记为‘v5.12-rc1-dontuse’ 。虽然内部依然写着‘v5.12-rc1’并且也是由我签名的 , 但是用户可见的标签名却变了” 。
文章图片
当 Torvalds 将某些代码标记为“dontuse” , 通常表明这个问题比较大 。在 5.12 首个候选版本更新中 , 破坏了交换文件(swapfile)的处理 。具体来说 , 更新后的代码会失去指向 swapfile 开头的正确偏移 。用 Torvalds 自己的话来说 , “交换还是会发生 , 但它发生在文件系统的错误部分 , 最终结果显然是灾难性的” 。
这样 Linux 内核如果想要将内存中的内容分页到磁盘上的时候 , 数据就会落在相同磁盘和 swapfile 活跃的分区的随机部分上 , 而且这不是作为文件 , 而是作为垃圾直接写入到磁盘的原始扇区 。这意味着不仅要覆盖现有文件中的数据 , 还要覆盖相当大块的元数据 , 这些元数据的损坏很可能会导致整个文件系统无法挂载和使用 。
Torvalds 继续指出 , 如果你根本不使用 swap , 那么这并不影响你 。不过如果你正在使用 swap 分区 , 而不是 swap 文件 , 你也同样不会受到影响 。
文章图片
据我所知 , 所有正常的发行版都是用swap分区 , 而不是文件来设置的 因为老实说 , swap 文件往往会比较慢 , 而且还有其他各种复杂的问题 。许多发行版仍然默认使用 swap分区 , 而不是文件 。但是Ubuntu--它可能是这个星球上部署最广泛的Linux发行版--已经默认安装 swapfiles四年多了 。而这个 bug 很可能会毁掉你的整个根文件系统 。
推荐阅读
- 功能|Linux 微信官方版 2.1.1 正式发布
- Linux|glibc在默认情况下并未妥善解决Y2038问题
- Intel|英特尔正为Linux 5.17准备PFRUT:升级系统固件无需重启
- Linux|Fedora 36默认字体将改为Noto,以覆盖更多语言
- Linux|Ubuntu Kylin 20.04 Pro(RISC-V)版本正式发布
- Linux|有人说,Linux 发行版激增不利于 Linux 生态系统?
- Linux|兆芯x86 CPU+国产OS:安卓App在桌面跑起来
- AMD|Linux 5.17将支持AMD智能追踪缓冲区功能
- Linux|国产Linux系统可爱鱼CutefishOS 0.7 Beta发布
- Intel|英特尔已为Linux 5.17准备了一些Wi-Fi改进