# tftpboot 1. [Overview](#overview) 2. [Description](#description) * [PXE files](#pxe-files) * [Configuration files](#configuration-files) * [Preseed](#preseed) * [Scripts](#scripts) 3. [How to use it](#how-to-use-it) 4. [TODO](#todo) ## Overview All needed files to set up a PXE server. ## Description ### PXE files Use some bootloaders files provide by : * `pxelinux` debian package : * gpxelinux.0 * pxelinux.0 * `syslinux-common` debian package : * chain.c32 * ldlinux.c32 * libcom32.c32 * libutil.c32 * menu.c32 * reboot.c32 * vesamenu.c32 To get those files from the packages of your repositories : ``` sh mkdir -p temp_pxe_files cd temp_pxe_files aptitude download pxelinux syslinux-common ar p pxelinux*.deb data.tar.xz | tar xJ -C . --strip-components=4 ./usr/lib/PXELINUX/{g,}pxelinux.0 ar p syslinux-common*.deb data.tar.xz | tar xJ -C . --strip-components=6 ./usr/lib/syslinux/modules/bios/{chain,ldlinux,libcom32,libutil,menu,reboot,vesamenu}.c32 ``` The MD5 checksum can mismatch between the files from this repo and those from Debian's packages. ### Configuration files Contains the files which defines the PXE menu. The [first one][main menu.cfg] will : * Call all others menu.cfg from subdirectories (debian/, clonezilla/,…) as an entry. * Define a timeout (4 seconds). * Define the default entry (boot on local first disk). * … #### config/debian/menu.cfg 1. Provide PXE entries for : * Debian Jessie (Stable) amd64. * Debian Jessie (Stable) amd64 with additionnals firmwares (see [make_debian_initrd_with_firmware.sh][debian initrd with firmware script] script). * Debian Jessie (Stable) amd64 with additionnals firmwares and preseed file. * Debian Jessie (Stable) amd64 for minions with preseed (Mate as default GUI). * Debian Jessie (Stable) amd64 for minions with preseed (Cinnamon as default GUI). * Debian Jessie (Stable) amd64 for minions with preseed (Gnome 3 as default GUI). * Debian Jessie (Stable) i386. * Debian Wheezy (oldStable) amd64 with additionnals firmwares (see [make_debian_initrd_with_firmware.sh][debian initrd with firmware script] script). * Debian Wheezy (oldStable) amd64 with additionnals firmwares and preseed file. * Debian Wheezy (oldStable) amd64 with preseed (Gnome 3 as default GUI). * Debian Wheezy (oldStable) i386. * Debian Sid (unstable) amd64. * Debian Sid (unstable) amd64 with additionnals firmwares (see [make_debian_initrd_with_firmware.sh][debian initrd with firmware script] script). * Debian Sid (unstable) i386. 2. If you want to use with your own TFTPD server, you need te set your IP server ! Replace all occurrences of *129.20.27.239* by the IP of your TFTPD server to be able to load the preseed files ! #### config/ubuntu/menu.cfg Provide PXE entries for : * Ubuntu LTS (16.04) amd64. * Ubuntu LTS (16.04) i386. * Latest non-LTS Ubuntu (15.10) amd64. * Latest non-LTS Ubuntu (15.10) i386. ### Preseed A preseed file can be loaded by the Debian-Installer to answer all questions Preseeding provides a way to set answers to questions asked by the Debian-Installer, without having to manually enter the answers. This makes it possible to fully automate most types of installation and even offers some features not available during normal installations. More informations on [Debian wiki][preseed informations]. #### Commons configurations * Localization : * Language : English * Country : France * Locale : en_US.UTF-8 (US English) * Keyboard : fr-latin9 (French) * Hardware : * Network configuration (IP, hostname, domain) : automatic (from DHCP server) * Load additionnals firmwares if availables. * Account : * Create a root account. * root password : SHA-256 hash of the password * Don't create a normal user (be sure to **allow remote connection for root** ! See [late_command info][debian latecommand howto]). * Timezone * Timezone : Europe/Paris * NTP server : ntp.univ-rennes1.fr * Partitionning * Use the entire first disk (sda or vda aka virtual hdd) with LVM. * Purge all LVM, RAID,… partitions or informations already set on the first disk. * Partitionning : | Device | Mount point | Size (Min - Max) | Description | |-----------|-------------|------------------------|------------------------------------------------------------------------| | /dev/sda1 | /boot | 200 - 250 Mb | Bootloader (Grub) | | /dev/sda2 | LVM | 16 Gb - 100% | Physical Volume for LVM | | lv_root | / | 1 - 2 Gb | Root partition | | lv_usr | /usr | 4 - 10 Gb | Non-essential system resources (binaries, libraries, documentations,…) | | lv_var | /var | 4 - 8 Gb | Variable files (databases, cache, log,…) | | lv_tmp | /tmp | 1 - 2 Gb | Temporary files cleaned between system reboots | | lv_home | /home | 2 - 3 Gb | User's home directories (saved files, personnal settings,…) | | lv_srv | /srv | 512 MB - 2 Gb | Specific datas for this system | | lv_opt | /opt | 512 MB - 4 Gb | Optional application | | lv_swap | SWAP | 512 Mb - 100% RAM size | Swap sapce | | lv_free | /mnt/free | free space | See below | * APT : * Installation from internet (repository : ftp.fr.debian.org) * Add a repository for Puppet (http://apt.puppetlabs.com) and the GPG key. * Select **ssh-server** and **standard** in _tasksel_ for installation. * Add additionnals packages : **tmux**, **puppet**, **zsh** and **tftp-hpa** (to be able to download the [latecommand archive from the PXE server][debian latecommand howto]). * Bootloader : * Install Grub on the MBR of the first disk. * late_command * Define ZSH as the default shell. * Permit root login via SSH with it's password. * Download and extract a _latecommand_ archive from [this repository][debian latecommand description]. * Run the script from this archive. ------ **lv_free - /mnt/free** : The preseed's partitionning need to allocate all the disk space. If it's not define, it will put it in the last defined partition all extra free space. So **lv_free** is a temporary LV that you can destroy and use the space to resize any other LV. #### Specific configurations * You can choose a desktop environment : * Debian Stable (aka Jessie) : Cinnamon, Mate or Gnome3 * Debian oldStable (aka Wheezy) : Gnome3 * Partitionning differences for Debian with a desktop environment : | Device | Mount point | Size (Min - Max) | Description | |---------|-------------|------------------|-------------------------------------------------------------| | lv_root | / | 1 - **3** Gb | root partition | | lv_home | /home | 2 - **10** Gb | User's home directories (saved files, personnal settings,…) | | lv_srv | NOT PRESENT | NOT PRESENT | | ### Scripts See the [scripts's README.md][scripts readme.md] file for more informations. ## How to use it * Put the data of this repository on the PXE server : * Clone the repository with https URL or with SSH to **/var/lib/tftpboot**. * Download the last archive : `wget https://git.ipr.univ-rennes1.fr/cellinfo/tftpboot/archive/master.tar.gz` * Install a TFTP server (`tftpd-hpa` package for Debian's based systems or `tftp-server` for Redhat's based systems). * Start the tftpd's service : * `sudo service tftpd-hpa start` * `sudo systemctl start tftpd-hpa` * You can test if the TFTP server provide the files with a TFTP client (`tftp-hpa`) by downloading a file with the command : `tftp $IP.SRV.TFTP -c get README.md /tmp/README.md_from_tftpd_server` * Set your IP in some files instead of the default one _129.20.27.239_ : * In configurations files to be able to call Debian's Preseed files or download squashfs filesystem (for Clonezilla, GParted,…): `sudo find config/ -iname "*.cfg" -type f -exec sed -i "s/129.20.27.239/111.222.333.444/g" {} \;` * In Preseed files, to be able to download the late_command archive from your TFTPD server : `sudo find preseed/ -type f -exec sed -i "s/129.20.27.239/111.222.333.444/g" {} \;` * In scripts to generate examples configuration files with the right IP address : `sudo find scripts/ -iname "*.sh" -type f -exec sed -i "s/129.20.27.239/111.222.333.444/g" {} \;` * Run scripts to download needed PXE files (see the [scripts's README.md][scripts readme.md] for more informations) : * Debian : `sudo ./scripts/download_debian.sh` * Debian's initrd with additionnals firmwares : `sudo ./scripts/make_debian_initrd_with_firmware.sh"` * Ubuntu : `sudo ./scripts/download_ubuntu.sh` * Diagnostic tools (Memtest86+, GParted Live,…) : `sudo ./scripts/download_diag_tools.sh` * Clonezilla : `sudo ./scripts/download_clonezilla.sh` * Generate the late_command archive : `cd scripts/ ; sudo tar czvf latecommand.tar.gz latecommand/` ## TODO * Add a tiny preseed file that could be loaded for a manual install. * Download the latecommand archive from this repository instead of the TFTPD server ? * Add Debian Stretch support #1 [main menu.cfg]: ./config/menu.cfg [debian menu.cfg]: ./config/debian/menu.cfg [preseed informations]: https://wiki.debian.org/DebianInstaller/Preseed [preseed jessie]: ./preseed/debian/jessie/preseed.cfg "Debian Jessie preseed" [preseed wheezy]: ./preseed/debian/wheezy/preseed.cfg "Debian Wheezy preseed" [scripts readme.md]: ./scripts/README.md "scripts's README.md for tftpboot" [debian initrd with firmware script]: ./scripts/README.md#make_debian_initrd_with_firmwaresh "informations about the Debian's initrd with additionnals firmwares" [debian latecommand description]: ./scripts/README.md#debian-late_command "informations about the Debian's late_command script" [debian latecommand howto]: ./scripts/README.md#how-to-use-it "how-to use the Debian's late_command" [debian latecommand post.sh script]: ./scripts/latecommand/post.sh