This is a release of the SURFsara package of utilities that we use to boot our nodes with PXE-enabled network cards. This was developed because we always want to use the PXE-enabled network card as our first boot device. With pxelinux, which is a derivative of syslinux, you can specify with a PXE configuration file how the node must boot. This configuration is placed in, e.g. /tftpboot/pxelinux.cfg directory.

We use this utility for the following purposes:

  • To instruct a node to do a memory test (memtest86 or Memtest86+) .
  • To instruct a node to flash its bios firmware or other firmware via the pxe dos boot method (memdisk)
  • Installation of a node with the aid of sali software

Setup example

SURFsara uses the following setup for:

We have a default setup. The default setup is to boot from hard disk. When a node boots it fetches the default configuration file and the configuration file instructs the node to boot from the hard-disk. At SURFsara we have developed the following strategy to install a fresh node:

  1. The ip-address in our setup is known for the new node. So we make a link in the /tftpboot/pxelinux.cfg directory to a pxe configuration file which instructs that it has to fetch the kernel and root filesystem from our boot server, eg: 0A000A02 ---> default.node_install (
  2. The client starts and uses the systemimager/sali software to install the node. The installation script connects to a daemon on the boot server. This daemon will remove the PXE config file/link for this node.
  3. The node reboots and uses the default pxe configuration file. Which will instruct the node to boot from hard-disk.


This release contains the following utilities (All utilities are written in Python):

  • This is daemon that removes the pxe configuration file of a node.
  • With this program we can specify which pxe configuration file a node or nodes must use. This utility will create the links in /tftpboot/pxelinux.cfg
  • Is a utility that diplays a directory, and, if in this directory contains HEX files, it will convert them to IP-numbers and hostnames.

PXE menu tools

Also included in this package are the PXE-menu tools which are used to control the booting of networked computers directly from the computer's console at the BIOS level before any operating system has been loaded. You get an on-screen hierarchical menu system which you navigate with the keyboard, and this allows you to select dynamically the tool or disk image to be booted. The PXE menus are based on the SYSLINUX menu systems.

The PXE menus are extremely useful for diagnostic purposes, for firmware upgrades, or for selecting an operating system installation method, of an individual computer while you work at its console (for remote management of multiple computers you probably want to use the pxeconfig tool in stead).

For Linux cluster node booting it is recommended to let the PXE menus be the default PXE boot method: With the example configuration the computer console will display the PXE menus for 5 seconds, allowing manual intervention if desired. After the 5 second timeout the computer will boot automatically from the hard disk.


How to install and make use of the pxeconfig package:

A useful link about how to use Systemimager and the pxeconfig tools is:

How to install and use the PXE menu tools:

A more detailed discussion of the PXE menu tools is currently in:

How to use the trac system

The system is configured for the following tasks:

Last modified 2 years ago Last modified on 02/13/13 11:21:44