GPT 磁盘在外部对接托架和内部交换托架中看起来不同

GPT 磁盘在外部对接托架和内部交换托架中看起来不同

我有一个硬盘,用于通过 USB 2.0 扩展坞进行备份。该磁盘有一个 GPT 和一个 ext4 分区。通过扩展坞一切都很好,但如果我将磁盘连接到内部 SATA 端口,或者将其放入 PC 的交换托架中,GPT 就不再存在了。

这是当磁盘位于扩展坞时我得到的结果,一切正常:

$ sudo fdisk -l /dev/sdg
Disk /dev/sdg: 1.8 TiB, 2000398934016 bytes, 488378646 sectors
Disk model: 001-1CH164
Units: sectors of 1 * 4096 = 4096 bytes
Sector size (logical/physical): 4096 bytes / 4096 bytes
I/O size (minimum/optimal): 4096 bytes / 4096 bytes
Disklabel type: gpt
Disk identifier: 2C0A0696-2318-4BBD-9329-0115AB5AC313
Device     Start       End   Sectors  Size Type
/dev/sdg1    512 488378367 488377856  1.8T Linux filesystem

$ sudo parted /dev/sdg print
Model: ST2000DM 001-1CH164 (scsi)
Disk /dev/sdg: 2000GB
Sector size (logical/physical): 4096B/4096B
Partition Table: gpt
Disk Flags:
Number  Start   End     Size    File system  Name      Flags
1      2097kB  2000GB  2000GB  ext4         MUSICBUP

以下是当磁盘位于内部交换托架或任何其他内部 SATA 端口时相同命令的输出:

$ sudo fdisk -l /dev/sdg
GPT PMBR size mismatch (488378645 != 3907029167) will be corrected by write.
Disk /dev/sdg: 1.8 TiB, 2000398934016 bytes, 3907029168 sectors
Disk model: ST2000DM001-1CH1
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 4096 bytes
I/O size (minimum/optimal): 4096 bytes / 4096 bytes
Disklabel type: dos
Disk identifier: 0x00000000
Device     Boot Start        End    Sectors  Size Id Type
/dev/sdg1           1 3907029167 3907029167  1.8T ee GPT
Partition 1 does not start on physical sector boundary.

$ sudo parted /dev/sdg print
Error: /dev/sdg: unrecognised disk label
Model: ATA ST2000DM001-1CH1 (scsi)
Disk /dev/sdg: 2000GB
Sector size (logical/physical): 512B/4096B
Partition Table: unknown
Disk Flags:

版本:fdisk from util-linux 2.33.1、 和parted (GNU parted) 3.2

操作系统:Debian 10 Buster4.19.0-14-amd64 #1 SMP Debian 4.19.171-2 (2021-01-30) x86_64 GNU/Linux

smartctl信息(两种情况相同):

=== START OF INFORMATION SECTION ===
Model Family:     Seagate Barracuda 7200.14 (AF)
Device Model:     ST2000DM001-1CH164
Serial Number:    Z1E6Q80D
LU WWN Device Id: 5 000c50 065bb1ceb
Firmware Version: CC27
User Capacity:    2,000,398,934,016 bytes [2.00 TB]
Sector Sizes:     512 bytes logical, 4096 bytes physical
Rotation Rate:    7200 rpm
Form Factor:      3.5 inches
Device is:        In smartctl database [for details use: -P show]
ATA Version is:   ACS-2, ACS-3 T13/2161-D revision 3b
SATA Version is:  SATA 3.1, 6.0 Gb/s (current: 6.0 Gb/s)
Local Time is:    Sun Mar 28 13:00:17 2021 CEST
SMART support is: Available - device has SMART capability.
SMART support is: Enabled

我已经尝试过的:使用 ,将分区向右移动gparted,以确保其与 MiB 对齐。这没有帮助,实际上parted已经告诉我分区已最佳对齐(在对接时)。

我注意到的一件事是,在外部对接 (4096) 和内部对接 (512) 时逻辑扇区大小不同。

当然,我将数据复制到其他地方,并且可以在将其连接到 PC 时重新格式化它,但我想从中学到一些东西,看看是否有办法纠正当前的 GPT。有任何想法吗?

答案1

不幸的是,GPT 仍然取决于逻辑扇区大小,并且在您的情况下它有所不同:

Sector size (logical/physical): 4096 bytes / 4096 bytes
Sector size (logical/physical): 4096B/4096B

Sector size (logical/physical): 512 bytes / 4096 bytes
Sector size (logical/physical): 512B/4096B

出现这种差异通常是因为某些控制器/USB 桥模拟了错误的扇区大小。

losetup您可以通过使用with参数来解决这个问题--sector-size

losetup --find --show --partscan --sector-size 4096 /dev/sdg

然后检查/dev/loopXpY设备。

如果您获得另一个不强制使用 4K 逻辑扇区大小的 USB 外壳,则必须为 512 字节扇区重新创建分区表。创建一个适用于两种扇区大小的分区表是不可能的 - 您可以使用 LVM 来做到这一点,但 LVM 不是一种分区表格式。

相关内容