Sie können einen TFTP-Server verwenden, um das ESXi-Installationsprogramm mit PXE zu starten. Der Prozess unterscheidet sich geringfügig, je nachdem, ob Sie UEFI verwenden oder über ein Legacy-BIOS starten.
- Für Legacy-BIOS-Maschinen unterstützt das Verfahren den Start mehrerer verschiedener Versionen des ESXi-Installationsprogramms mithilfe desselben anfänglichen pxelinux.0-Bootloaders für alle Zielmaschinen, wobei aber je nach MAC-Adresse der Zielmaschine möglicherweise unterschiedliche PXELINUX-Konfigurationsdateien verwendet werden.
- Für UEFI-Maschinen unterstützt das Verfahren den Start mehrerer verschiedener Versionen des ESXi-Installationsprogramms mithilfe desselben anfänglichen mboot.efi-Bootloaders für alle Zielmaschinen, wobei aber je nach MAC-Adresse der Zielmaschine möglicherweise unterschiedliche boot.cfg-Dateien verwendet werden.
Voraussetzungen
Da die meisten Umgebungen neben
ESXi-Hosts, die UEFI-Starts unterstützen, auch Hosts enthalten, die ausschließlich Legacy-BIOS unterstützen, werden in diesem Thema Voraussetzungen und Schritte für beide Hosttypen behandelt.
Überprüfen Sie, ob die Umgebung die folgenden Voraussetzungen erfüllt:
- ISO-Image des ESXi-Installationsprogramms, das von der VMware-Website heruntergeladen wurde.
- Zielhosts mit einer Hardwarekonfiguration, die für Ihre ESXi-Version unterstützt wird. Weitere Informationen finden Sie im VMware-Kompatibilitätshandbuch.
- Netzwerkadapter mit PXE-Unterstützung auf dem ESXi-Zielhost
- DHCP-Server, den Sie für den PXE-Startvorgang konfigurieren können. Weitere Informationen hierzu finden Sie unter DHCP-Beispielkonfigurationen.
- TFTP-Server.
- Netzwerksicherheitsrichtlinien zum Zulassen des TFTP-Datenverkehrs (UDP-Port 69)
- Für Legacy-BIOS können Sie nur IPv4-Netzwerke verwenden. Zum Starten von UEFI mit PXE können Sie IPv4- oder IPv6-Netzwerke verwenden.
- (Optional) Installationsskript (Kickstart-Datei).
- In den meisten Fällen ist die Verwendung eines nativen VLANs sinnvoll. Wenn Sie die VLAN-ID angeben möchten, die mit dem PXE-Startvorgang verwendet wird, stellen Sie sicher, dass Ihre Netzwerkkarte die VLAN-ID-Spezifikation unterstützt.
Rufen Sie Version 3.86 des SYSLINUX-Pakets für Legacy-BIOS-Systeme ab. Weitere Informationen finden Sie unter
Hintergrundinformationen zum Netzwerkstart.
Prozedur
- Wenn auf Ihrem ESXi-Host nur Legacy-BIOS-Firmware ausgeführt wird, rufen Sie PXELINUX ab und konfigurieren Sie diese Datei.
- Rufen Sie SYSLINUX Version 3.86 ab, entpacken Sie das Programm und kopieren Sie die Datei pxelinux.0 in das Verzeichnis /tftpboot der obersten Ebene auf dem TFTP-Server.
- Erstellen Sie eine PXELINUX-Konfigurationsdatei mithilfe des folgenden Codemodells.
ESXi-8.x.x-XXXXXX ist der Name des TFTP-Unterverzeichnisses, das die Dateien des
ESXi-Installationsprogramms enthält.
DEFAULT install
NOHALT 1
LABEL install
KERNEL ESXi-8.x.x-XXXXXX/mboot.c32
APPEND -c ESXi-8.x.x-XXXXXX/boot.cfg
IPAPPEND 2
- Speichern Sie die Datei PXELINUX im Verzeichnis /tftpboot/pxelinux.cfg auf dem TFTP-Server mit einem Dateinamen, der angibt, ob alle Hosts dieses Installationsprogramm standardmäßig starten:
Option |
Beschreibung |
Dasselbe Installationsprogramm |
Geben Sie der Datei den Namen default, wenn alle Hosts dieses ESXi-Installationsprogramm standardmäßig starten sollen. |
Verschiedene Installationsprogramme |
Benennen Sie die Datei mit der MAC-Adresse der Zielhostmaschine (01-mac_address_of_target_ESXi_host), wenn nur ein bestimmter Host mit dieser Datei gestartet werden soll, z. B. 01-23-45-67-89-0a-bc. |
- Wenn auf Ihrem ESXi-Host UEFI-Firmware ausgeführt wird, kopieren Sie die Dateien efi/boot/bootx64.efi und efi/boot/crypto64.efi aus dem ISO-Image des ESXi-Dienstprogramms in das Verzeichnis /tftpboot auf Ihrem TFTP-Server.
- Benennen Sie die Datei efi/boot/bootx64.efi in mboot.efi um.
Hinweis: Neuere Versionen der Datei
mboot.efi können in der Regel ältere Versionen von
ESXi starten. Ältere Versionen der Datei
mboot.efi hingegen können neuere Versionen von
ESXi unter Umständen nicht starten. Wenn Sie verschiedene Hosts konfigurieren möchten, um unterschiedliche Versionen des
ESXi-Installationsprogramms zu starten, verwenden Sie die Datei
mboot.efi aus der neuesten Version.
- Konfigurieren Sie den DHCP-Server.
- Erstellen Sie ein Unterverzeichnis des obersten /tftpboot-Verzeichnisses des TFTP-Servers und benennen Sie es nach der enthaltenen ESXi-Version, z. B. /tftpboot/ESXi-8.x.x-xxxxx.
- Kopieren Sie den Inhalt des Images des ESXi-Installationsprogramms in das neu erstellte Verzeichnis.
- Bearbeiten Sie die Datei boot.cfg.
- Fügen Sie folgende Zeile hinzu:
prefix=ESXi-7.x.x-xxxxxx
Hier stellt
ESXi-7.x.x-xxxxxx
den Pfadnamen der Installationsprogrammdateien relativ zum Root-Verzeichnis des TFTP-Servers dar.
- Wenn die Dateinamen in den
kernel=
- und modules=
-Zeilen mit einem umgekehrten Schrägstrich (/) beginnen, löschen Sie dieses Zeichen.
- Wenn die kernelopt=-Zeile die Zeichenfolge cdromBoot enthält, entfernen Sie nur die Zeichenfolge.
- (Optional) Fügen Sie für eine Skriptinstallation in der boot.cfg-Datei die Option
kernelopt
in die Zeile nach dem Kernelbefehl ein, um den Speicherort des Installationsskripts anzugeben.
Verwenden Sie den folgenden Code als Beispiel, wobei
XXX.XXX.XXX.XXX die IP-Adresse des Servers ist, auf dem sich das Installationsskript befindet, und
esxi_ksFiles das Verzeichnis, in dem sich die Datei
ks.cfg befindet.
kernelopt=ks=http://XXX.XXX.XXX.XXX/esxi_ksFiles/ks.cfg
- Wenn auf Ihrem ESXi-Host UEFI-Firmware ausgeführt wird, geben Sie an, ob alle UEFI-Hosts dasselbe Dienstprogramm starten sollen.
Option |
Beschreibung |
Dasselbe Installationsprogramm |
Kopieren Sie die Datei boot.cfg in das Verzeichnis /tftpboot/boot.cfg oder verknüpfen Sie sie mit diesem Verzeichnis. |
Verschiedene Installationsprogramme |
- Erstellen Sie ein Unterverzeichnis von /tftpboot, das nach der MAC-Adresse der Zielhostmaschine (01-mac_address_of_target_ESXi_host) benannt ist, z. B. 01-23-45-67-89-0a-bc.
- Legen Sie eine Kopie (oder eine Verknüpfung mit) der Datei boot.cfg des Hosts in diesem Verzeichnis ab, z. B. /tftpboot/01-23-45-67-89-0a-bc/boot.cfg.
|