How to Configure a PXE Server in CentOS/RHEL 7
The Preboot Execution Environment (PXE) is an industry-standard client/server interface that allows networked computers that are not yet loaded with an operating system to be configured and booted remotely by an administrator. Let us work on CentOS/RHEL 7 to configure a PXE Server to boot and install CentOS/RHEL 7 OS in the client configuration. First setup Static IP Address for PXE server, this is important. you can edit the network configuration file or use nmcli command to setup. For setting up the static IP address click here to know more.
data:image/s3,"s3://crabby-images/cdb3c/cdb3cb8e2c71b851c0ba10da30dd9196cd90c237" alt="PXE Server configuration in RHEL 7"
Check the details with nmcli command more information about the Network settings.
# nmcli con show eno16777736
data:image/s3,"s3://crabby-images/427d9/427d9498c047d7c16e2e036de561e7374a7992da" alt="nmcli command"
Install vsftpd and createrepo packages into the server using YUM. this is to configure the software repo.
# yum install vsftpd createrepo
data:image/s3,"s3://crabby-images/4f1e4/4f1e4a048701321826b6b6f3e9203ee92a63cd53" alt="install vsftpd and createrepo"
Mount the RHEL 7 DVD in the server to copy the packages required to configure software repo.
# mount -t iso9660 /dev/sr0 /mnt
data:image/s3,"s3://crabby-images/fc66e/fc66eb87381e88b3b1a6e7326767bbf607dada39" alt="Mount RHEL 7 DVD"
Create a directory /rhel7/dvd/ under /var/ftp/pub to hold the dvd packages and copy the DVD contents to this directory.
# mkdir -p /var/ftp/pub/rhel7/dvd/
# cp -rv /mnt/* /var/ftp/pub/rhel7/dvd/
data:image/s3,"s3://crabby-images/b9086/b908600c3b157d0503bd9a2b51c025f6fe031a22" alt="Create directory for RHEL 7 packages"
Create yum client configuration file under /etc/yum.repos.d. Enter the following details.
data:image/s3,"s3://crabby-images/1c88f/1c88fc494c2b8d0ca1ac769b73c6df4d8d685d9d" alt="create yum client configuration file"
For running group commands like grouplist, groupinstall we need to copy *-comps-Server.x86_64.xml and using this file we need to update the metadata again using the following commands.
# cd /var/ftp/pub/rhel7/dvd/repodata/
# cp 76a190afa1c59e14d3a03f9b03c3eee31df0099f1193528ebb87d4d493d2b686-comps-Server.x86_64.xml /var/ftp/pub/rhel7/dvd/group-comps-Server.x86_64.xml
# createrepo -vg /var/ftp/pub/rhel7/dvd/group-comps-Server.x86_64.xml /var/ftp/pub/rhel7/dvd/
data:image/s3,"s3://crabby-images/91212/912125db8d7442a595aad1459375f734a343f40c" alt="update the metadata using createrepo command"
data:image/s3,"s3://crabby-images/daa06/daa0677cf18a6071edc200ca6f5fcdf746e753ea" alt="createrepo update metadata centos 7"
Test the yum configuration and yum group file settings using yum grouplist command.
data:image/s3,"s3://crabby-images/18e12/18e12df5b3a961f5935dd83d21e353254d65356a" alt="test yum grouplist"
Now install the Kickstart packages using YUM for configuring the kickstart input file.
data:image/s3,"s3://crabby-images/446f5/446f526504da9bfa1329b1a27598ec1df5e6c43b" alt="install the Kickstart packages"
Install Apache software into this server using YUM.
# yum install httpd
data:image/s3,"s3://crabby-images/28eda/28eda7ee5225c223c7f85bd280f33f26e26bdff2" alt="start vsftpd and httpd service"
Now create a soft link of /var/ftp/pub into /var/www/html directory so that you can access this repository and installation tree using FTP or HTTP Protocol.
# ln -s /var/ftp/pub/ /var/www/html/
Update the SELINUX context for these directory using restorecon command.
# restorecon -Rv /var/ftp/pub/
# restorecon -Rv /var/www/html/
Start the service for vsftpd and httpd using following commands.
# systemctl start vsftpd
# systemctl start httpd
# systemctl enable vsftpd
# systemctl enable httpd
data:image/s3,"s3://crabby-images/45e63/45e63fff8fc674efb985567beaddc1a8f152ef63" alt="start httpd and vsftpd"
Now create a kickstart file for unattended installation of CentOS/RHEL 7 OS. to create kickstart unattended file run “system-config-kickstart utility. Now you could see a window similar to the below. provide the required information and save it under /var/ftp/pub directory.
data:image/s3,"s3://crabby-images/108ca/108ca395d01a524a752ca7206baa59abdca925c6" alt="Create kickstart file system-config-kickstart"
Another way to create kickstart file to copy the /root/anaconda-ks.cfg file to /var/ftp/pub and edit according to your requirement. Here is my kickstart file.
data:image/s3,"s3://crabby-images/31c85/31c8512a24d8949936fd3a3bb429d777910dad26" alt="create anaconda-ks.cfg file"
Now restart the vsftp and httpd services.
# systemctl restart vsftpd
# systemctl restart httpd
data:image/s3,"s3://crabby-images/278fe/278fec3457db9d85cee8e16ec49f682c9ce4eea8" alt="restart vsftpd and httpd services"
Check whether you are able to access the ks.cfg using http. use firefox or links to check it.
# links http://192.168.1.25/pub/ks.cfg
If it’s successful then you will get this screen.
data:image/s3,"s3://crabby-images/c6601/c660139c6cbd9e823d187cc5166271c88a5617e7" alt="acacess the ks.cfg using http"
Now we need to install the packages for PXE boot. Install syslinux, xinetd, tftp-server, and DHCP using YUM.
# yum install syslinux xinetd tftp-server dhcp -y
data:image/s3,"s3://crabby-images/5664d/5664d7a0a5cf3ab9c9396dd2fda7f77882f1add6" alt="Install syslinux, xinetd, tftp-server and dhcp using YUM"
Create a directory pxe configuration directory named “pxelinux.cfg” in /var/lib/tftpboot.
# mkdir /var/lib/tftpboot/pxelinux.cfg
data:image/s3,"s3://crabby-images/baa55/baa5514ea99c6b5fe0bf74d7fb6b23e15e96c56c" alt="create pxe configuration directory pxelinux.cfg"
Now copy the “/usr/share/syslinux/pxelinux.0” to “/var/lib/tftpboot” directory.
# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
data:image/s3,"s3://crabby-images/ac297/ac2973fe6f28de6511ff78bc7793dea5af1d51ab" alt="copy pxelinux.0"
Enable tftp service. edit the /etc/xinetd.d/tftp file and enable the xinetd configuration. This is used to provide pxe kernel to client.
data:image/s3,"s3://crabby-images/c72b3/c72b3150102ddad9dd79911cbdf2edc9483bee89" alt="Enable tftp service"
Start and enable tftp server (xinetd) service. Run the following commands.
# systemctl start xinetd
# systemctl enable xinetd
data:image/s3,"s3://crabby-images/590a0/590a0c9846160e968ccc9b1e2511ab0d56c225be" alt="Start and enable tftp server"
Now configure DHCP service. This is used to give the IP address to clients. To configure DHCP copy the sample configuration from /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example to /etc/dhcp/dhcpd.conf.
# cp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf
data:image/s3,"s3://crabby-images/7f87b/7f87bcc57b95a8ec518ec36b59251d13c5cf9cf4" alt="configure DHCP service"
Now edit the configuration file /etc/dhcp/dhcpd.conf and add the following lines.
allow booting;
allow bootp;
authoritative;
# This is a very basic subnet declaration.
subnet 192.168.1.0 netmask 255.255.255.0 {
range 192.168.1.26 192.168.1.40;
option routers 192.168.1.25;
default-lease-time 21600;
max-lease-time 43200;
}
# This declaration allows BOOTP clients to get dynamic addresses,
# which we don't really recommend.
subnet 192.168.1.0 netmask 255.255.255.0 {
range dynamic-bootp 192.168.1.101 192.168.1.111;
option broadcast-address 192.168.1.255;
option routers 192.168.1.25;
option domain-name "vinzlinux.com";
default-lease-time 21600;
max-lease-time 43200;
filename "pxelinux.0";
next-server 192.168.1.25;
}
data:image/s3,"s3://crabby-images/b9800/b980005c30326b100a866d1f49ec70bbe1a6611c" alt="edit dhcpd.conf"
Restart the dhcpd service and enabled it using the following command.
# systemctl restart dhcpd
# systemctl enable dhcpd
data:image/s3,"s3://crabby-images/1d279/1d279f4f3041da103cf6889b40613a0fa80d46d2" alt="Restart the dhcpd service and enabled it"
Now copy the following files from CentOS/RHEL 7 to /var/lib/tftpboot/ for creating the PXE server.
# cd /var/ftp/pub/rhel7/dvd/images/pxeboot/
# cp initrd.img /var/lib/tftpboot/
# cp vmlinuz /var/lib/tftpboot/
# cp /usr/share/syslinux/menu.c32 /var/lib/tftpboot/
# cd /var/ftp/pub/rhel7/dvd/isolinux/
# cp -rvf * /var/lib/tftpboot/
data:image/s3,"s3://crabby-images/d90bd/d90bda1f08222f9fa4a0f3c712ecab2d1eb20f86" alt="PXE server configuration rhel centos"
Now create a PXE boot menu. create a file named “default” under /var/lib/tftpboot/pxelinux.cfg directory. and add the following lines.
default vesamenu.c32
timeout 600
display boot.msg
menu background splash.png
ONTIMEOUT local
MENU TITLE Vinil's PXE Menu
label linux
menu label ^Install System from PXE
kernel vmlinuz
append initrd=initrd.img ks=http://192.168.1.25/pub/ks.cfg ksdevice=eno16777736 ip=dhcp
label local
menu label Boot from ^local drive
localboot 0xffff
data:image/s3,"s3://crabby-images/26e66/26e6604f2650f02d28845c180b99071b25df2abd" alt="create a PXE boot menu"
Now restart the vsftpd and httpd service and not boot the client and check the configuration. You could see a below screen in the PXE client machine.
data:image/s3,"s3://crabby-images/e908d/e908d471c6abb59ce7c7a64b68c620c9d77b1959" alt="restart the vsftpd and httpd service"
Select it and you would see that it starts installing the RHEL7.0 os on the client.
data:image/s3,"s3://crabby-images/5e118/5e1186e5d0bb40e70ce12de30a04a5d23b5d01f2" alt="starts installing the RHEL7.0 os on the client"
That’s all about the PXE server configuration. I hope you found this useful.