fdisk -l показывает файловую систему ext3 как HPFS / NTFS

14

У меня есть внешний жесткий диск, который я отформатировал как раздел NTFS в Windows. Теперь я отформатировал этот жесткий диск в моей системе Linux с помощью команды ниже.

mkfs.ext3 /dev/sdb1

Он был успешно отформатирован. Тем не менее, когда я запускаю fdisk -lкоманду, она дает мне систему NTFS / HPFS.

   Device Boot      Start         End      Blocks   Id  System
   /dev/sdb1               1      121601   976760001   83  HPFS/NTFS

Тем не менее, команда df -T /dev/sdb1все еще давала мне тип файловой системы как ext3.

Почему при запуске fdisk -lкоманды система не отображается как Linux ?

Рамеш
источник

Ответы:

15

При настройке диска или раздела есть 2 аспекта для этого. Первый - это создание схемы таблицы разделов на диске с использованием форматов MBR (Master Boot Record) или GPT (GUID Partitioning Table) . Оба из них устанавливают «структуру» на диске.

MBR

Если вы посмотрите на структуру MBR, вы заметите, что есть раздел, предназначенный для определения «типа» разделов.

                          сс макета

Допустимые типы разделов для MBR:

Command (m for help): l

 0  Empty           24  NEC DOS         81  Minix / old Lin bf  Solaris        
 1  FAT12           27  Hidden NTFS Win 82  Linux swap / So c1  DRDOS/sec (FAT-
 2  XENIX root      39  Plan 9          83  Linux           c4  DRDOS/sec (FAT-
 3  XENIX usr       3c  PartitionMagic  84  OS/2 hidden C:  c6  DRDOS/sec (FAT-
 4  FAT16 <32M      40  Venix 80286     85  Linux extended  c7  Syrinx         
 5  Extended        41  PPC PReP Boot   86  NTFS volume set da  Non-FS data    
 6  FAT16           42  SFS             87  NTFS volume set db  CP/M / CTOS / .
 7  HPFS/NTFS/exFAT 4d  QNX4.x          88  Linux plaintext de  Dell Utility   
 8  AIX             4e  QNX4.x 2nd part 8e  Linux LVM       df  BootIt         
 9  AIX bootable    4f  QNX4.x 3rd part 93  Amoeba          e1  DOS access     
 a  OS/2 Boot Manag 50  OnTrack DM      94  Amoeba BBT      e3  DOS R/O        
 b  W95 FAT32       51  OnTrack DM6 Aux 9f  BSD/OS          e4  SpeedStor      
 c  W95 FAT32 (LBA) 52  CP/M            a0  IBM Thinkpad hi eb  BeOS fs        
 e  W95 FAT16 (LBA) 53  OnTrack DM6 Aux a5  FreeBSD         ee  GPT            
 f  W95 Ext'd (LBA) 54  OnTrackDM6      a6  OpenBSD         ef  EFI (FAT-12/16/
10  OPUS            55  EZ-Drive        a7  NeXTSTEP        f0  Linux/PA-RISC b
11  Hidden FAT12    56  Golden Bow      a8  Darwin UFS      f1  SpeedStor      
12  Compaq diagnost 5c  Priam Edisk     a9  NetBSD          f4  SpeedStor      
14  Hidden FAT16 <3 61  SpeedStor       ab  Darwin boot     f2  DOS secondary  
16  Hidden FAT16    63  GNU HURD or Sys af  HFS / HFS+      fb  VMware VMFS    
17  Hidden HPFS/NTF 64  Novell Netware  b7  BSDI fs         fc  VMware VMKCORE 
18  AST SmartSleep  65  Novell Netware  b8  BSDI swap       fd  Linux raid auto
1b  Hidden W95 FAT3 70  DiskSecure Mult bb  Boot Wizard hid fe  LANstep        
1c  Hidden W95 FAT3 75  PC/IX           be  Solaris boot    ff  BBT            
1e  Hidden W95 FAT1 80  Old Minix      

Таким образом, в вашем случае раздел идентифицируется как тип 17.

Формат файловой системы

Вторым аспектом является форматирование пространства внутри самого раздела (файловой системы). Эти файловые системы больше всего знакомы при работе с EXT3 / 4 и т. Д.

Итак, в вашем случае вы смешали тип раздела и файловую систему, которые обычно не сочетаются друг с другом. Я должен упомянуть здесь, что такие инструменты, как fdisk«тупые» в том смысле, что они обычно позволяют вам делать все, что вы хотите, независимо от того, имеет ли это смысл или нет.

Изменение типа раздела

Поэтому для решения вашей проблемы вам нужно изменить тип раздела на 83, если это пустой раздел, отформатированный как EXT4, или 8e, если это раздел LVM. Хорошей новостью является то, что вы можете использовать fdiskдля изменения типа разделов с помощью tфункции:

   t   change a partition's system id

После успешного выполнения этого ваши разделы должны выглядеть примерно так:

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048     1026047      512000   83  Linux
/dev/sda2         1026048   976773119   487873536   8e  Linux LVM

Что бы я сделал!

Однако в вашем случае, поскольку тип раздела, по-видимому, указан уже как 83, а раздел указан как HPFS / NTFS, я думаю, что я был бы склонен удалить все разделы вместе и начать все заново с чистого листа.

SLM
источник
1
Большое спасибо за чудесное объяснение. Я записал 30 ГБ данных на этот жесткий диск, система которого в настоящее время является HPFS / NTFS. Если я использую команду fdisk -t для изменения типа раздела на Linux, означает ли это, что он удалит 30 ГБ данных, которые присутствуют на диске?
Рамеш,
Я никогда не пытался изменить тип диска, когда совершил такую ​​же ошибку, как и в прошлом. В общем, информация таблицы разделов отделена от ваших данных, поэтому данные должны быть оставлены без изменений. Я думаю, что сначала я это сделаю, а потом попытаюсь изменить. Также, если вы не монтируете раздел в Windows, вы можете оставить все как есть. Linux не заботится о типе, только Windows будет, когда / если он попытается смонтировать его.
SLM
Прямое доказательство: у меня был раздел в формате ext4 с идентификатором типа 7 и соответственно идентифицированный как HPFS / NTFS / exFAT. t с 83переименованием диска как Linux, без потери данных :)
Иоганн
6

Таблица idв разделе не имеет ничего общего с тем, что на самом деле находится в разделе. Например, для файловой системы XFS нет типа - люди просто используют «linux» (83). fdiskбудет говорить HPFS / NTFS, пока вы не измените тип раздела:

fdisk /dev/sdb
t 1
83
w

Затем перезагрузите или снова подключите диск. (убедитесь, что он не установлен первым)

Рики Бим
источник
Мне тоже было интересно об этом. По сути, изменение этого числа не имеет никакого отношения (до тех пор, пока я не изменю его на раздел подкачки или что-то в этом роде)?
Palswim