Table of Contents
1 Install PXE Boot server
The following script will install PXE Boot server. Change the variables to your environment.
- SERVER_IPADDR is IP adress of PXE Boot server.
- DHCP_SUBNET is network address for DHCP.
- DHCP_NETMASK is subnet for DHCP.
- DHCP_DOMAIN is domain for DHCP.
- DHCP_DNS is DNS for DHCP.
- DHCP_ROUTER is gateway for DHCP.
- DHCP_CLIENT_HOSTNAME is hostname of client.
- DHCP_CLIENT_IPADDR is IP address of client.
- DHCP_CLIENT_MACADDR is MAC address of client.
- KICKSTART_LANGUAGE is language for Kickstart.
- KICKSTART_KEYMAP is keyboard layout for Kickstart.
- KICKSTART_TIMEZONE is time zone for Kickstart.
- MIRROR_URL is repository URL for network installation.
Preseed runs the following.
- Set root user password to “fedora”.
- Create user which name is “fedora” and password is “fedora”.
- Password is hashed with this.
- Install packages for GNOME desktop environment.
- This article creates fedora-26-ks.cfg. But you can use /root/anaconda-ks.cfg by making “cdrom” to comment out.
#!/bin/shset -e# Change the following variable to yours.[ -z “${SERVER_IPADDR}” ] && SERVER_IPADDR=$(hostname -I | awk ‘{ print $1 }’)[ -z “${DHCP_SUBNET}” ] && DHCP_SUBNET=192.168.11.0[ -z “${DHCP_NETMASK}” ] && DHCP_NETMASK=255.255.255.0[ -z “${DHCP_DOMAIN}” ] && DHCP_DOMAIN=hiroom2.com[ -z “${DHCP_DNS}” ] && DHCP_DNS=”192.168.11.2, 192.168.11.1″[ -z “${DHCP_ROUTER}” ] && DHCP_ROUTER=192.168.11.1[ -z “${DHCP_CLIENT_HOSTNAME}” ] && DHCP_CLIENT_HOSTNAME=fedora-26-pxeboot-client[ -z “${DHCP_CLIENT_IPADDR}” ] && DHCP_CLIENT_IPADDR=192.168.11.254[ -z “${DHCP_CLIENT_MACADDR}” ] && DHCP_CLIENT_MACADDR=52:54:00:5e:7a:a4[ -z “${KICKSTART_LANGUAGE}” ] && KICKSTART_LANGUAGE=en_US.UTF-8[ -z “${KICKSTART_KEYMAP}” ] && KICKSTART_KEYMAP=jp[ -z “${KICKSTART_TIMEZONE}” ] && KICKSTART_TIMEZONE=Asia/Tokyoif [ -z “${MIRROR_URL}” ]; then F26=https://dl.fedoraproject.org/pub/fedora/linux/releases/26 MIRROR_URL=${F26}/Everything/x86_64/os/fitftp_server_install(){ sudo dnf install -y tftp-server sudo firewall-cmd –add-service=tftp –permanent sudo firewall-cmd –reload sudo systemctl enable tftp sudo systemctl restart tftp}dhcp_install(){ sudo dnf install -y dhcp cat <<EOF | sudo tee /etc/dhcp/dhcpd.confsubnet ${DHCP_SUBNET} netmask ${DHCP_NETMASK} { option domain-name “${DHCP_DOMAIN}”; option domain-name-servers ${DHCP_DNS}; option routers ${DHCP_ROUTER}; next-server ${SERVER_IPADDR}; filename “pxelinux.0”;}host ${DHCP_CLIENT_HOSTNAME} { hardware ethernet ${DHCP_CLIENT_MACADDR}; fixed-address ${DHCP_CLIENT_IPADDR};}EOF sudo firewall-cmd –add-service=dhcp –permanent sudo firewall-cmd –reload sudo systemctl enable dhcpd sudo systemctl restart dhcpd}nfs_utils_install(){ sudo dnf install -y nfs-utils sudo firewall-cmd –add-service=nfs –permanent sudo firewall-cmd –reload sudo systemctl enable nfs sudo systemctl restart nfs sudo mkdir /var/lib/nfsroot cat <<EOF | sudo tee /etc/exports/var/lib/nfsroot *(rw,sync,no_root_squash,no_subtree_check)EOF sudo exportfs -ra}syslinux_install(){ sudo dnf install -y syslinux cd /var/lib/tftpboot sudo cp /usr/share/syslinux/pxelinux.0 . sudo cp -a /usr/share/syslinux . sudo wget -q ${MIRROR_URL}/isolinux/initrd.img sudo wget -q ${MIRROR_URL}/isolinux/vmlinuz sudo mkdir pxelinux.cfg cat <<EOF | sudo tee pxelinux.cfg/defaultpath syslinuxinclude menu.cfgdefault syslinux/vesamenu.c32prompt 0timeout 50EOF cat <<EOF | sudo tee menu.cfgmenu hshift 13menu width 49menu margin 8menu tabmsgmenu title automated install boot menulabel fedora-26-automated-install menu label ^Fedora 26 automated install kernel vmlinuz append vga=788 initrd=initrd.img ip=dhcp inst.repo=${MIRROR_URL} ks=nfs:${SERVER_IPADDR}:/var/lib/nfsroot/fedora-26-ks.cfgmenu endEOF}kickstart_install(){ root_passwd=$(python -c “import cryptprint(crypt.crypt(“fedora”, crypt.mksalt(crypt.METHOD_SHA512)))”) user_passwd=$(python -c “import cryptprint(crypt.crypt(“fedora”, crypt.mksalt(crypt.METHOD_SHA512)))”) cat <<EOF | sudo tee /var/lib/nfsroot/fedora-26-ks.cfg%preif [ -b /dev/vda ]; then echo “ignoredisk –only-use=vda” > /tmp/drive-ks.cfg echo “bootloader –location=mbr –boot-drive=vda” >> /tmp/drive-ks.cfgelse echo “ignoredisk –only-use=sda” > /tmp/drive-ks.cfg echo “bootloader –location=mbr –boot-drive=sda” >> /tmp/drive-ks.cfgfi%end%include /tmp/drive-ks.cfgauth –enableshadow –passalgo=sha512graphicalfirstboot –disableeula –agreedkeyboard –vckeymap=${KICKSTART_KEYMAP} –xlayouts=’${KICKSTART_KEYMAP}’lang ${KICKSTART_LANGUAGE}network –bootproto=dhcp –device=eth0 –ipv6=auto –activatenetwork –hostname=${DHCP_CLIENT_HOSTNAME}rootpw –iscrypted ${root_passwd}timezone ${KICKSTART_TIMEZONE} –isUtcuser –groups=wheel –name=fedora –password=${user_passwd} –iscryptedxconfig –startxonbootautopart –type=lvmclearpart –none –initlabelreboot# Fedora Workstation.%packages@^workstation-product-environment%end%addon com_redhat_kdump –disable –reserve-mb=’128’%endEOF}pxeboot_main(){ tftp_server_install dhcp_install nfs_utils_install syslinux_install kickstart_install}pxeboot_main
2 Install Fedora 26 automatically
This article installs Fedora 26 on virtual machine on KVM. Virtual machine on VirtualBox and real machine too can be installed Fedora 26 automatically with enabling network boot. Please check your BIOS setting.
Enable “NIC” of “Boot device order” with virt-manager. If CDROM is not empty or Disk is already installed some OS, you need to change order in order to NIC be top.
iPXE sends DHCP requests, receives DHCP response from PXE Boot server, download and run boot image.
syslinux’s menu is displayed. After 5 seconds, “Fedora 26 automated install” will be selected automatically.
Automated install is started.
Virtual machine is rebooted automatically when automated install is completed. Installed Fedora 26 is started.