Partitionsausrichtung

Last change on 2020-09-28 • Created on 2020-03-17 • ID: RO-5F72D

Einleitung

Unter Partition Alignment versteht man das richtige Ausrichten von Partitionen an den physikalisch Sektorgrenzen eines Datenträgers (z.B. Festplatte, SSD, RAID-Volume). Ein korrektes Partition Alignment gewährleistet eine optimale Performance bei Datenzugriffen. Speziell bei SSDs (mit internen Page-Größen von beispielsweise 4.096 oder 8.192 Bytes), Festplatten mit 4 KiB (4.096 Bytes) Sektoren und RAID Volumes führt eine fehlerhafte Ausrichtung von Partitionen zu verminderter Performance.

Allgemeine Informationen

Bei der Installation von Betriebssystemen über den Robot oder unter Verwendung von installimage im Hetzner Rescue-System wird die Ausrichtung automatisch korrekt vorgenommen.

Bei eigenständigen Installation via KVM-Konsole oder via VNC (z.B. CentOS 6.X) muß die Ausrichtung selbst vorgenommen werden. Als Faustregel gilt, daß je neuer das zu installierende Betriebsystem, desto höher die Wahrscheinlichkeit, daß die Partitionen vom Installationsprogramm korrekt ausgerichtet werden. Das Aligment kann durch folgende Befehle überprüft werden:

sfdisk -uS -l
fdisk -u -l /dev/sdX

Der Startsektor jeder Partition sollte mindestens durch 8 (8 * 512 Byte = 4KiB), im Optimalfall durch 2048 (2048 * 512 Byte = 1 MiB) teilbar sein.

Background: Partitionierung

Traditionell arbeiten Festplatten mit einer physischen Sektorgröße von 512 Byte. Die erste Partition beginnt dabei im letzten Sektor der ersten Spur mit der (logischen) Blockadresse 63. Die Größe eines solchen (logischen) Sektors beträgt ebenfalls 512 Byte. Da logische und die physikalische Sektorgröße gleich sind, gibt es keinerlei Probleme. Neuere Festplatten im sogenannten Advanced Format arbeiten intern mit einer physischen Sektorgröße von 4.096 Byte (4 KiB). Nach außen emulieren sie aber weiter eine Sektorgröße von 512 Byte (Advanced Formate 512e). Auch SSDs arbeiten mit einer Pagegröße von 4 KiB beziehungsweise 8 KiB. Bei diesen Festplatten bzw. SSDs ist die "klassische" Partitionierung beginnend ab LBA-Adresse 63 nicht mehr zu empfehlen.

Aktuelle Dateisysteme wie zum Beispiel ext4 oder ntfs nutzen eine Blockgröße von 4 KiB. Die 4 KiB Dateisystem-Blöcke passen nun nicht direkt in die 4 KiB Sektoren der Festplatte bzw. 4 KiB / 8 KiB Pages der SSDs. Beim Schreiben eines einzelnen 4 KiB Dateisystem-Blockes müssen dann zwei 4 KiB Sektoren bzw. Pages verändert werden. Erschwerend kommt dabei hinzu, dass die jeweiligen 512 Byte Blöcke erhalten bleiben müssen - es kommt damit zu einem Read/Modify/Write. Die Folge ist eine deutlich verminderte Performance.

Wrong Partition Alignment

Korrekte Partitionierung

Um dieses Problem zu vermeiden empfiehlt sich ein Alignment auf 1 MiB - damit ist man auf lange Sicht auf der sicheren Seite. Mit der aktuellen Adressierung in 512 Byte großen logischen Sektoren entspricht das 2048 Sektoren.

Correct Partition Alignment

Linux

fdisk (ältere Versionen)

Bei älteren fdisk Versionen können Sie manuell über die Paramater -S und -H ein Alignment erreichen. Bezüglich der konkreten Number of Sectors per Track (S) und Number of Head (H) Zahlen finden sich unterschiedliche Empfehlungen. Mit -S 32 -H 64 sind die Partitionen auf 1 MiB aligned (32 Sektoren pro Track * 64 Heads * 512 Byte = 1.048.576 Byte = 1 MiB). Beim Erstellen der ersten Partition beginnen Sie dabei bei Zylinder 2. Ohne spezielle Parameter kommt es zu einem Misalignment durch fdisk.

fdisk im Hetzner Rescue System

Die im Hetzner Rescue-System enthaltene fdisk Version nutzt ein 1MiB Alignment sofern der DOS-Kompatibilitätsmodus deaktiviert wird.

Die Empfehlung bei neueren fdisk Versionen lautet:

  • verwenden Sie fdisk von util-linux-ng >= 2.17.2
  • beachten Sie Warnungen von fdisk
  • deaktivieren Sie den DOS-compatible mode (-c Option)
  • verwenden Sie Sektoren als Display Units (-u Option)
  • verwenden Sie +size{M,G} um das Ende einer Partition anzugeben

Beispiel fehlerhaftes Alignment

Das folgende Beispiel zeigt ein fehlerhaftes Alignment nach einer VNC-Installation von CentOS 5.6:

[root@static ~]# fdisk -v
fdisk (util-linux 2.13-pre7)
[root@static ~]# fdisk -u /dev/hda

The number of cylinders for this disk is set to 10443.
There is nothing wrong with that, but this is larger than 1024,
and could in certain setups cause problems with:
1) software that runs at boot time (e.g., old versions of LILO)
2) booting and partitioning software from other OSs
   (e.g., DOS FDISK, OS/2 FDISK)

Command (m for help): p

Disk /dev/hda: 85.8 GB, 85899345920 bytes
255 heads, 63 sectors/track, 10443 cylinders, total 167772160 sectors
Units = sectors of 1 * 512 = 512 bytes

   Device Boot      Start         End      Blocks   Id  System
/dev/hda1   *          63      208844      104391   83  Linux
/dev/hda2          208845   167766794    83778975   8e  Linux LVM

Beispiel korrektes Alignment

root@rescue ~ # fdisk -c -u /dev/sda

Command (m for help): p

Disk /dev/sda: 1500.3 GB, 1500301910016 bytes
255 heads, 63 sectors/track, 182401 cylinders, total 2930277168 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 4096 bytes
I/O size (minimum/optimal): 4096 bytes / 4096 bytes
Disk identifier: 0x0004dc67

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1            2048     4196351     2097152   fd  Linux raid autodetect
/dev/sda2         4196352     5244927      524288   fd  Linux raid autodetect
/dev/sda3         5244928  1465149167   729952120   fd  Linux raid autodetect

LVM and Software RAID

Obwohl auch hier auf ein korrektes Alignment geachtet werden muß, ist dies in der Regel nicht explizit notwendig, da mindestens 64 KiB große Blöck verwendet werden. Neuere Version enthalten Patches, die zusätzlich ein Alignment auf 1 MiB-Grenzen vornehmen.

Windows

Alle Windows Versionen ab Windows Vista führen automatisch ein Alignment auf MiB-Grenzen bei allen Datenträgern größer als 4 GiB durch. Ältere Versionen wie Windows XP benötigen ein manuelles Alignment.

Table of Contents