- 我在单独的磁盘上有一个双引导 Windows 10 和 Ubuntu 伴侣(F8 引导选择)。
- 我在 RST 上的 Windows 10 中制作了一个 RAID-0 块,它可以作为辅助磁盘正常工作。这个块并不意味着启动,只是为了在两个系统之间存储和共享数据。
我在 Ubuntu Mate 上看不到这个 raid 块的分区,虽然 gdisk 没有列出分区, gnome-disk-utility 看到 GPT,但没有要挂载的分区。
$ sudo gdisk -l /dev/dm-0
[sudo] Mot de passe de wingarmac :
GPT fdisk (gdisk) version 1.0.8
Partition table scan:
MBR: protective
BSD: not present
APM: not present
GPT: present
Found valid GPT with protective MBR; using GPT.
Disk /dev/dm-0: 3907039744 sectors, 1.8 TiB
Sector size (logical/physical): 512/4096 bytes
Disk identifier (GUID): F554FF29-FF7D-4A79-8D05-3ADF30EF3BED
Partition table holds up to 128 entries
Main partition table begins at sector 2 and ends at sector 33
First usable sector is 34, last usable sector is 3907039710
Partitions will be aligned on 8-sector boundaries
Total free space is 2527 sectors (1.2 MiB)
Number Start (sector) End (sector) Size Code Name
1 34 32767 16.0 MiB 0C01 Microsoft reserved ...
2 32768 3907035135 1.8 TiB 0700 Basic data partition
3 3907035136 3907037183 1024.0 KiB 8300
我用开始菜单打开 Gparted,我可以看到我的 RAID-0 显示为: /dev/mapper/isw_cfjifbibag_Volume1 我无法以这种方式在 Gparted 中进行任何修改。
我可以看到我的 RAID 块在 gnome-disk-utility 中被调用:/dev/dm-0
我尝试使用终端和命令打开 Gparted:
$ sudo gparted /dev/dm-0
我试了一下,将“基本数据分区”上的标志更改为irst
,然后改回msftres
. 这使得分区映射到 /dev/mapper/isw_module_Volume1p1。我什至可以浏览文件夹并在已安装的分区上创建内容。重启后问题依旧。它似乎重置了操作完成。即使在我尝试更改 gnome-disks 中的挂载选项之后。
我发现 /etc/mtab 是存储当前磁盘映射(如 USB 驱动器和其他热插拔)的位置。我尝试将有关正确分区挂载的行添加到 fstab,但重新启动后分区未挂载:
/dev/mapper/isw_cfjifbibag_Volume1p2 /media/wingarmac/Data fuseblk rw,nosuid,nodev,relatime,user_id=0,group_id=0,default_permissions,allow_other,blksize=4096 0 0
恢复问题:
线索 1:为什么我的 raid 块有两个映射?:
- /dev/mapper/isw_cfjifbibag_Volume1
- /dev/dm-0
这个问题的答案似乎是 /dev/mapper/isw_cfjifbibag_Volume1 是在引导时检测到的 raid 卷设备,而 /dev/dm-0 是该驱动器用于驱动器系统安装的映射。
线索 2:为什么我需要更改标志才能挂载 ntfs 分区?
当我这样做时,就像对分区进行了新的检查,并启用了这些分区的驱动器映射。
线索3:为什么重启后不能自动挂载这个分区?
我发现 Windows 使用 GPT 将磁盘初始化为 2Tb。还建议磁盘应该包含更多为 4 个分区。关键是 Ubuntu 在启动时似乎并没有照顾 GPT 磁盘上的 MBR 分区。列出了我的 dm-0(GPT 磁盘),但没有映射 dm-1(包含 MBR 分区)。
当我使用 gparted /dev/dm-0 时,我能够看到包含的 MBR NTFS 分区和另一个保留的分区。通过将分区上的标志更改为任何其他标志并返回,使分区映射到 /dev/dm-1。然后 gparted 能够验证它,因为它是映射的。在验证过程中,gparted 请求调整大小,导致“不需要调整大小”。但这使得分区能够被 Ubuntu 挂载。尽管重启后一切都重置了,即使我在 fstab 中输入了挂载详细信息。
关键是封装的 MBR 在启动时未映射到 dm-1。它似乎甚至没有被检测到,因为 dm-1 被映射,卷 /dev/mapper/isw_module_Volume1p1 还没有被发现。只有块 (/dev/mapper/isw_module_Volume1) 和 raid 成员在引导后在 gdisk 中列出。
当我输入命令时:
$ sudo file -s /dev/dm-0
我得到这些结果:
/dev/dm-0 DOS/MBR 引导扇区 MS-MBR Windows 7 英语在偏移量 0x163 “无效分区表”在偏移量 0x17b “错误加载操作系统”在偏移量 0x19a “缺少操作系统”,磁盘签名 0x87d4000f;分区 1 : ID=0x27, start-CHS (0x0,32,33), end-CHS (0x3ff,254,63), startsector 2048, 3907033088 个扇区
该分区是在 Windows 上创建的,但 Windows 安装在另一个驱动器上。就像驱动器在启动时未映射,因为它无法在其上找到系统。我不需要这个分区作为启动项,只是它会自动挂载在 Ubuntu 中。我可以禁用此磁盘/分区上的操作系统检查吗?
我想知道在检测到这个磁盘/分区时是否可以重复 gparted 在启动时所做的操作。以下是能够挂载它的 Gparted GUI 操作示例: gparted_details
通过使用命令,我找到了有关块设备的 UUID 的重要信息:
udevadm info -a -n /dev/dm-0
这给了我这个驱动器上 UUID 的结果:ATTR{dm/uuid}=="DMRAID-isw_cfjifbibag_Volume1"
现在我只收到关于我的 raid-0 的以下错误,使用命令sudo journalctl -p 3
kernel: ntfs3: Unknown parameter 'windows_names'
但是挂载点上不再出现 fstab 错误,并且仍然没有映射分区。
我找到了一种在重新启动后映射分区的更好方法,而不是使用 gparted。现在我只需要输入命令:sudo dmraid -ay -f isw
结果:
RAID set "isw_cfjifbibag_Volume1" already active
RAID set "isw_cfjifbibag_Volume1p1" was activated
现在我可以像其他人一样将分区挂载在 gnome-disk 中。剩下的唯一问题是,在此设备上更新 GRUB 毫无意义,因为它是用于存储的。所以我不知道如何让引导过程进行检查dmraid -ay -f isw
,而不是dmraid -ay
像看起来那样。
我在 Ubuntu Help 上的这个页面的帮助下找到了解决方案,这部分包含一个小错误:
预引导环境呢?默认软件包 dmraid 附带的脚本不足以实际激活阵列上的分区。您必须将脚本复制到 /etc 并附加它:
最后一个命令给了我结果:
所以我打开文件夹/etc/initramfs-tools/scripts/local-top并在其中看到一个文件 dmraid。我认为这是为了将此命令添加到此文件中。
所以我通过自己编辑文件来手动完成。使 dmraid 查找带有 Intel 元数据的分区所需的命令:
应在引导时考虑此命令。因此,我们需要将此命令添加到文件夹/etc/initramfs-tools/scripts/local-top中名为dmraid的文件中的脚本中,如下所示:
特别说明:
对于全新安装,不要忘记在编辑后重新安装 dmraid
/etc/initramfs-tools/scripts/local-top/dmraid
通过以 root 身份使用命令:
apt install --reinstall dmraid libdmraid1.0.0.rc16
就像在Ubuntu 帮助页面上提到的那样
现在我在 Intel RST 上的 dmraid NTFS 分区即使在重新启动后也会自动挂载。我只需要在/etc/fstab中再次激活这条线: