[[Vorlage(Getestet, general)]] {{{#!vorlage Wissen [:Terminal: Ein Terminal öffnen] }}} [[Inhaltsverzeichnis(1)]] '''UUID''' steht für '''U'''niversally '''U'''nique '''Id'''entifier und bezeichnet nach einem bestimmten Standard formatierte Identifikationsnummern. Diese sehen etwa so aus: * ``6a12a4d5-e9e6-4568-afcc-34c70b24a668`` Jedes Linux-Dateisystem besitzt einen UUID, über den es identifiziert werden kann. Zwar kann man das auch über die Device-Dateien ``/dev/sdaX`` tun, aber die Nummerierung kann sich hier ändern - z.B. beim Vertauschen von Kabeln. Andere Eigenschaften wie [:Labels:Label] oder Größe des Dateisystems garantieren keine Eindeutigkeit. Vergleichen kann man den UUID also mit einer Personalausweisnummer: Zwei Personen können den gleichen Namen tragen, sie haben aber trotzdem verschiedene Ausweisnummern. UUIDs werden üblicherweise mit Verfahren erzeugt, die darauf ausgelegt sind, dass ein solcher Identifikator eindeutig ist. Die Wahrscheinlichkeit, dass zwei generierte UUIDs gleich sind, ist also verschwindend gering. Bei der Verwendung solcher eindeutigen Identifikationsnummern sind der Phantasie keine Grenzen gesetzt; in diesem Artikel geht es nur um den Einsatz bei Dateisystemen. Seit [:Edgy Eft#UUIDs:] werden die im System vorhandenen Dateisysteme (inklusive Swap) in der [:fstab:] und in der [:menu.lst:] standardmäßig mittels UUID angesprochen. Die Windows-Dateisysteme FAT und NTFS verwenden keine UUIDs, sondern die "Volume Serial Number". Unter Linux wird diese vom Dateisystemtreiber als UUID-Ersatz verwendet. Die Volume Serial Number ist deutlich kürzer als ein UUID und garantiert daher keine Eindeutigkeit: ||<-4 rowclass="titel"> Vergleich verschiedener Identifikatoren || || Typ || UUID || Serial Number (NTFS) || Serial Number (FAT) || || Format || xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx || xxxxxxxxxxxxxxxx || xxxx-xxxx || || Länge || 16 Bytes || 8 Bytes || 4 Bytes || || Anzahl der möglichen Identifikatoren || 2^^(8·16)^^ ≈ 3.4 · 10^^(38)^^ || 2^^(8·8)^^ ≈ 18 · 10^^(18)^^ || 2^^(8·4)^^ ≈ 4.3 · 10^^(9)^^ || [[Anker(anzeigen)]] = UUIDs anzeigen = {{{#!vorlage Hinweis Der Befehl sudo benötigt für den ersten Aufruf grundsätzlich [:sudo: root-Rechte]. Desweiteren sollte man auf jeden Fall beachten, dass die UUIDs nach dem ersten Aufruf in der Datei '''/etc/blkid.tab''' zwischengespeichert werden. Nach dem ersten Aufruf wird dann nur noch diese Datei ausgelesen, anstatt alle Datenträger erneut abzufragen. Informationen, wie man diese Verhalten verhindern kann findet man im Artikel [:blkid:]. }}} Mit dem Befehl [1] {{{#!vorlage Befehl sudo blkid /dev/sda1 }}} Alle UUIDs der vorhandenen Dateisysteme liefert {{{#!vorlage Befehl sudo blkid }}} oder {{{#!vorlage Befehl ls -Al /dev/disk/by-uuid }}} Mehr Informationen zum Befehl blkid findet man [:blkid:hier]. [[Anker(aendern)]] = UUIDs verändern = [[Vorlage(Fortgeschritten)]] Der UUID wird beim Formatieren eines Laufwerks automatisch generiert und braucht normalerweise nicht geändert zu werden. In gewissen Fällen kann dies aber sinnvoll sein, z.B. nach einer Festplattenspiegelung, bei der der UUID mitkopiert wurde. Je nach verwendetem Dateisystem sind hierfür unterschiedliche Befehle erforderlich. Generell sollte man jedoch vorher unbedingt ein [:Backup:] anlegen und das Dateisystem [:mount:aushängen]. {{{#!vorlage Hinweis Im folgenden muss ``/dev/sdaX`` jeweils durch die Bezeichnung der zu ändernden Partition ersetzt werden. }}} == Ext2/3 == {{{#!vorlage Befehl sudo tune2fs -U NEUER_UUID /dev/sdaX }}} Hierbei kann ``NEUER_UUID`` entweder ein (z.B. mit '''uuidgen''') selbst erstellter UUID sein oder eines dieser Schlüsselwörter: * ``random`` - setzt einen zufälligen UUID * ``time`` - setzt einen aus der aktuellen Uhrzeit generierten UUID * ``clear`` - Abkürzung für ``00000000-0000-0000-0000-000000000000`` == Reiserfs == {{{#!vorlage Befehl sudo reiserfstune -u NEUER_UUID /dev/sdaX }}} ``NEUER_UUID`` muss ein gültiger UUID sein. Um automatisch mit ``uuidgen`` einen zufälligen UUID zu erzeugen, kann man diesen Befehl verwenden: {{{#!vorlage Befehl sudo reiserfstune -u $(uuidgen) /dev/sdaX }}} == Swap == {{{#!vorlage Hinweis Die Funktion zum setzen des UUID von Swap-Dateisystemen wurde erst in [:Hardy_Heron: Ubuntu 8.04] eingeführt. Für frühere Ubuntu-Versionen kann man [bug:186274:bei launchpad.net] {en} das entsprechende mkswap-Programm herunterladen. Alternativ kann man die Änderungen manuell durchführen (s.u.), wobei man ``POS=1036`` und ``SIZE=16`` wählt. }}} {{{#!vorlage Befehl sudo swapoff -v /dev/sdaX sudo mkswap -U NEUER_UUID /dev/sdaX sudo swapon -v /dev/sdaX }}} Es existiert ein Skript, das die UUID aus '''/etc/fstab''' automatisch übernimmt: [:Skripte/UUID_anpassen_mit_uuid2swap:uuid2swap]. == FAT / NTFS == Wie bereits erwähnt, kommt bei den Windows-Dateisystemen kein UUID zum Einsatz, sondern eine Seriennummer. Um diese zu bearbeiten, benötigt man Handarbeit: Zunächst extrahiert man die aktuelle Nummer mit {{{#!vorlage Befehl sudo dd if=/dev/sdaX of=/tmp/serial bs=1 skip=POS count=SIZE }}} Die Werte für ``POS`` und ``SIZE`` sind gemäß dieser Tabelle zu wählen: || || FAT16 || FAT32 || NTFS || || POS || 39|| 67 || 72 || || SIZE || 4|| 4 || 8 || Nun kann man die Datei '''/tmp/serial''' mit einem Hex-Editor (z.B. ``ghex2`` oder ``khexedit``) öffnen und bearbeiten. Sie sollte nichts weiter als die Seriennummer enthalten, und zwar im [wikipedia:Byte-Reihenfolge:Little Endian-Format] (also "rückwärts"). Zunächst sollte man sich davon überzeugen, dass dies der Fall ist. Dann nimmt man die gewünschten Änderungen mit dem Hex-Editor vor und speichert die Datei ab. Schließlich schreibt man mit {{{#!vorlage Befehl sudo dd if=/tmp/serial of=/dev/sdaX bs=1 seek=POS count=SIZE }}} die neue Seriennummer zurück. Die Werte für POS und SIZE müssen wieder wie oben gesetzt werden. {{{#!vorlage Hinweis Beim Auslesen der Seriennummer verwendet man den Parameter ``skip=``, beim Schreiben ``seek=`` }}} = Links = * [wikipedia:Universally_Unique_Identifier:Wikipedia-Artikel "UUID"] * [http://technet2.microsoft.com/WindowsServer/en/library/50cd4ffc-1389-423d-9d02-1a898b2eb39f1033.mspx Technische Spezifikation FAT] {en} * [http://technet2.microsoft.com/WindowsServer/en/library/8cc5891d-bf8e-4164-862d-dac5418c59481033.mspx Technische Spezifikation NTFS] {en} ---- # tag: Hardware, System