AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 770013
Accepted
ForDummies
ForDummies
Asked: 2024-02-24 09:41:04 +0800 CST2024-02-24 09:41:04 +0800 CST 2024-02-24 09:41:04 +0800 CST

如何擦除或禁用驱动器的启动信息

  • 772

我有一台有 5 个硬盘的计算机,但是当我停止 BIOS 来查看我的选择时,它有 14 个启动选项(包括 DVD,但我们忽略它)。这些是 BIOS 中的选项,而不是 GRUB 中的选项,因此每一项都会带我进入 GRUB 菜单,而且它们并不完全相同。由于我正在清理不久前造成的灾难,并且根据一般原则,我想删除除前两个驱动器之外的所有驱动器中的引导信息和 grub 加载程序。

其中一些驱动器采用 GPT 格式,一些采用 MBR 格式。有Windows 10和Xubuntu系统。显然,这 14 个中有 UEFI 和标准启动视图。所有这些都反映了它的历史,始于 2002 年。此后主板和其他东西发生了变化,但很多数据仍然存在。

我很想破坏大多数驱动器上的前 512 字节,但我 (a) 不确定这是否足够,(b) 不确定它是否完全安全。

那么清理这个问题的最佳实践是什么?

boot
  • 1 1 个回答
  • 25 Views

1 个回答

  • Voted
  1. Best Answer
    telcoM
    2024-02-24T17:44:02+08:002024-02-24T17:44:02+08:00

    覆盖驱动器上的前 512 个字节肯定会使 BIOS 可引导磁盘不可引导。它还会破坏 MBR 分区表,因此任何 MBR 分区的磁盘在此之后都将显示为空且未分区。因此,不要对您希望保留其分区的任何磁盘执行此操作。

    如果磁盘是 MBR 分区但可 UEFI 引导(即,其上有 FAT 类型文件系统,分区类型代码设置为 0xef,并且该分区包含\EFI\BOOT\BOOTx64.efi64 位 x86 系统路径中的文件),则覆盖分区table 是多余的:要使磁盘不可 UEFI 启动,您所需要做的就是删除该文件或将其重命名为其他名称。

    对于 GPT 分区的 UEFI 可启动磁盘,覆盖前 512 字节根本不起作用:某些磁盘分区工具可能会注意到保护性 MBR 似乎已损坏,并且很可能会提供自动修复或作为修复的副作用对 GPT 分区表执行任何其他操作都没有任何问题。

    BIOS 菜单中的额外启动选项很可能是过时的 UEFI 启动变量:正如 oldfred 在评论中建议的那样,sudo efibootmgr -v在 Linux 中使用来查看它们,识别BootXXXX过时条目的数量,然后使用sudo efibootmgr -B -b XXXX来删除它们。

    在不破坏分区表的情况下使 BIOS 可启动磁盘无法启动实际上有点棘手:我知道的最简单的方法是一个名为 的小实用程序ms-sys,它可以写入多种类型的 BIOS 主引导记录和分区引导记录...包括不起眼的“不可启动磁盘”主启动记录。

    不幸的是,该实用程序似乎在现代 Ubuntu 的软件包存储库中不可用。其源代码可在https://sourceforge.net/projects/ms-sys/获取(如果您不喜欢 SourceForge,则可以在https://github.com/pbatard/ms-sys上镜像旧版本)。如果您安装了gcc和make通用应用程序开发库,您应该能够使用以下命令构建它:

    <download the source code package>
    tar xvf xvf ms-sys-2.8.0.tar.gz
    cd ms-sys-2.8.0
    make && sudo make install
    

    如果成功,您现在应该可以/usr/local/bin/ms-sys在 处找到该工具及其手册页/usr/local/man/man1/ms-sys.1(可通过简单的 进行查看man ms-sys)。

    要使 BIOS 可启动磁盘/dev/sdX无法启动,请使用ms-sys:

    sudo ms-sys --mbrzero /dev/sdX
    

    --mbrzero手册页上该选项的描述是:

    -z, --mbrzero

    将空(清零、不可引导)主引导记录写入设备。将除分区映射和签名 id(字节 01be-01ff)之外的所有字节清零。类似于 fdisk 创建的空 DOS 分区表。

    事实上,它避免覆盖分区表(由于某种原因称为“分区映射”)和磁盘签名字节是重要的部分。

    • 1

相关问题

  • 为什么 `journalctl --list-boots` 与 `uptime` 和 `who -b` 报告的不匹配?

  • 如何在启动时启动控制台程序(在 ../openbox/autostart 内)

  • 系统完好,grub坏了

  • “pacman -Syu”“可能”破坏了我的系统,因为未安装引导

  • 克隆的 SSD 无法启动并打印奇怪的线条

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve