PXE Boot

PXE Boot #

Einführung #

Als Preboot eXecution Environment (PXE) wird eine Technik bezeichnet, die es ermöglicht, über das Netzwerk beliebigen ausführbaren Code oder auch Nutzdaten zu verteilen. Dies kann zum Beispiel genutzt werden, um Notfallsysteme oder Installationsmedien ohne USB-Stick zur Verfügung zu haben.

Setup eines PXE Servers #

Folgende Software wird benötigt:

  • DHCP-Server (dhcpd, dnsmasq)
  • TFTP-Server (tftp-hpa, dnsmasq)
  • NFS-Server / HTTP Server (nfs-server, nginx, darkhttpd)
  • Bootloader (syslinux)

Der Client, der gebootet werden soll, muss eine PXE-fähige Netzwerkkarte haben. Der PXE Code führt dann zuerst über DHCP eine Konfiguration der Schnittstelle durch und erhält damit auch die erweiterten Informationen wie die TFTP Server- und Bootloaderdatei Adresse. Im Anschluss kann der Client das initiale Network Bootstrap Program (NBP) laden und im Arbeitsspeicher ausführen. Ein mögliches Bootloaderprogramm ist PXELinux.

sequenceDiagram
    participant C as PXE-Client
    participant S as DHCP-Server (PXE-fähig)
    participant T as TFTP-Server

    C->>+S: Extended DHCP Discover Port 67
    S-->>-C: Extended DHCP Offer Port 68
    C->>+S: DHCP Request Port 67
    S-->>-C: DHCP Boot Ack. Reply Port 68

    C->>+S: Boot Service Discover Port 67 oder 4011
    S-->>-C: Boot ServiceAck. Reply Port 67 oder 4011

    C->>+T: Bootstrap Program Download Request Port 69
    T-->>-C: Bootstrap Program Download Port 69

Proxy DHCP #

Da der DHCP Server nicht immer unter der Kontrolle des Entwicklers ist, wird die Proxy DHCP Lösung benötigt. Dazu wird zum herkömmlichen DHCP Austausch noch ergänzende Informationen vom Proxy DHCP Server gesendet.

Beispiel Setup #

In diesem Beispiel wird Syslinux direkt vom Archlinux Iso verwendet.

Es werden 4 Images konfiguriert (2 Mal Archlinux, Clonezilla)

Dateistruktur #

Die ISO-Datei soll gemountet werden und daraus werden dann die nötigen Dateien kopiert. Der Syslinux Ordner wird der Root-Ordner. Anschliessend wird im Root-Ordner ein Verzeichnis angelegt, wo die Images (z.B. Clonezilla, Archlinux etc.) abgelegt werden sollen.

tftp
├── hdt
├── images
│   ├── arch
│   │   ├── boot
│   │   │   ├── x86_64
│   │   │   │   ├── initramfs-linux.img
│   │   │   │   └── vmlinuz-linux
│   │   ├── x86_64
│   │   │   ├── airootfs.sfs
│   │   │   ├── airootfs.sfs.sig
│   │   │   └── airootfs.sha512
│   ├── archlinux-2021.06.01-x86_64.iso
│   └── clonezilla-live-2.7.2-39-amd64.iso
├── archiso_head.cfg
├── archiso_pxe.cfg
├── archiso_pxe-linux.cfg
├── archiso_sys.cfg
├── archiso_sys-linux.cfg
├── archiso_tail.cfg
├── lpxelinux.0
├── splash.png

DHCP Server #

interface=vboxnet0
listen-address=192.168.56.1
dhcp-range=192.168.56.10,192.168.56.30,12h
dhcp-option-force=209,syslinux.cfg
dhcp-boot=lpxelinux.0
enable-tftp
tftp-root=/mnt/tftp
log-dhcp

Syslinux Config #

syslinux.cfg #

DEFAULT select

LABEL select
COM32 whichsys.c32
APPEND -pxe- pxe -sys- sys -iso- sys

LABEL pxe
CONFIG archiso_pxe.cfg

LABEL sys
CONFIG archiso_sys.cfg

archiso_pxe.cfg #

INCLUDE archiso_head.cfg

INCLUDE archiso_pxe-linux.cfg

INCLUDE archiso_tail.cfg

archiso_head.cfg #

SERIAL 0 115200
UI vesamenu.c32
MENU TITLE Arch Linux
MENU BACKGROUND splash.png

MENU WIDTH 78
MENU MARGIN 4
MENU ROWS 7
MENU VSHIFT 10
MENU TABMSGROW 14
MENU CMDLINEROW 14
MENU HELPMSGROW 16
MENU HELPMSGENDROW 29

# Refer to http://syslinux.zytor.com/wiki/index.php/Doc/menu

MENU COLOR border       30;44   #40ffffff #a0000000 std
MENU COLOR title        1;36;44 #9033ccff #a0000000 std
MENU COLOR sel          7;37;40 #e0ffffff #20ffffff all
MENU COLOR unsel        37;44   #50ffffff #a0000000 std
MENU COLOR help         37;40   #c0ffffff #a0000000 std
MENU COLOR timeout_msg  37;40   #80ffffff #00000000 std
MENU COLOR timeout      1;37;40 #c0ffffff #00000000 std
MENU COLOR msg07        37;40   #90ffffff #a0000000 std
MENU COLOR tabmsg       31;40   #30ffffff #00000000 std

MENU CLEAR
MENU IMMEDIATE

archiso_pxe-linux.cfg #


# Entpacktes ISO, es wird ein HTTP Server benötigt
LABEL arch64_http
TEXT HELP
Boot the Arch Linux live medium using HTTP.
It allows you to install Arch Linux or perform system maintenance.
ENDTEXT
MENU LABEL Arch Linux install medium (x86_64, HTTP)
LINUX /images/arch/boot/x86_64/vmlinuz-linux
INITRD /images/arch/boot/intel-ucode.img,/images/arch/boot/amd-ucode.img,/images/arch/boot/x86_64/initramfs-linux.img
APPEND archisobasedir=/images/arch archiso_http_srv=http://${pxeserver}/ checksum verify
SYSAPPEND 3

# ISOs
LABEL arch-iso
LINUX memdisk
INITRD /images/archlinux-2021.06.01-x86_64.iso
APPEND iso

LABEL clonezilla-iso
LINUX memdisk
INITRD /images/clonezilla-live-2.7.2-39-amd64.iso
APPEND iso

archiso_tail.cfg #

LABEL existing
TEXT HELP
Boot an existing operating system.
Press TAB to edit the disk and partition number to boot.
ENDTEXT
MENU LABEL Boot existing OS
COM32 chain.c32
APPEND hd0 0

# http://www.memtest.org/
LABEL memtest
MENU LABEL Run Memtest86+ (RAM test)
LINUX /arch/boot/memtest

# http://hdt-project.org/
LABEL hdt
MENU LABEL Hardware Information (HDT)
COM32 hdt.c32
APPEND modules_alias=hdt/modalias.gz pciids=hdt/pciids.gz

LABEL reboot
TEXT HELP
Reboot computer.
The computer's firmware must support APM.
ENDTEXT
MENU LABEL Reboot
COM32 reboot.c32

LABEL poweroff
TEXT HELP
Power off computer.
The computer's firmware must support APM.
ENDTEXT
MENU LABEL Power Off
COM32 poweroff.c32
Calendar September 21, 2021