From dcad76a0f9e4b0ce71fe58ef7df00aad5bc62086 Mon Sep 17 00:00:00 2001 From: DeadFire Date: Tue, 23 Dec 2014 13:39:39 +0800 Subject: [PATCH] =?UTF-8?q?20141223-1=20=E9=80=89=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...ution Installations in RHEL or CentOS 7.md | 306 ++++++++++++++++++ 1 file changed, 306 insertions(+) create mode 100644 sources/tech/20141223 Setting up a 'PXE Network Boot Server' for Multiple Linux Distribution Installations in RHEL or CentOS 7.md diff --git a/sources/tech/20141223 Setting up a 'PXE Network Boot Server' for Multiple Linux Distribution Installations in RHEL or CentOS 7.md b/sources/tech/20141223 Setting up a 'PXE Network Boot Server' for Multiple Linux Distribution Installations in RHEL or CentOS 7.md new file mode 100644 index 0000000000..195decc20c --- /dev/null +++ b/sources/tech/20141223 Setting up a 'PXE Network Boot Server' for Multiple Linux Distribution Installations in RHEL or CentOS 7.md @@ -0,0 +1,306 @@ +Setting up a ‘PXE Network Boot Server’ for Multiple Linux Distribution Installations in RHEL/CentOS 7 +================================================================================ +**PXE Server** – Preboot eXecution Environment – instructs a client computer to boot, run or install an operating system directly form a network interface, eliminating the need to burn a CD/DVD or use a physical medium, or, can ease the job of installing Linux distributions on your network infrastructure on multiple machines the same time. + +![Setting PXE Network Boot in RHEL/CentOS 7](http://www.tecmint.com/wp-content/uploads/2014/10/Setting-PXE-Network-Boot-in-CentOS.png) +Setting PXE Network Boot in RHEL/CentOS 7 + +#### Requirements #### + +- [CentOS 7 Minimal Installation Procedure][1] +- [RHEL 7 Minimal Installation Procedure][2] +- [Configure Static IP Address in RHEL/CentOS 7][3] +- [Remove Unwanted Services in RHEL/CentOS 7][4] +- [Install NTP Server to Set Correct System Time in RHEL/CentOS 7][5] + +This article will explain how you can install and configure a **PXE Server** on **RHEL/CentOS 7** x64-bit with mirrored local installation repositories, sources provided by CentOS 7 DVD ISO image, with the help of **DNSMASQ** Server. + +Which provides **DNS** and **DHCP** services, **Syslinux** package which provides bootloaders for network booting, **TFTP-Server**, which makes bootable images available to be downloaded via network using **Trivial File Transfer Protocol** (TFTP) and **VSFTPD** Server which will host the local mounted mirrored DVD image – which will act as an official RHEL/CentOS 7 mirror installation repository from where the installer will extract its required packages. + +### Step 1: Install and configure DNSMASQ Server ### + +**1.** No need to remind you that is absolutely demanding that one of your network card interface, in case your server poses more NICs, must be configured with a static IP address from the same IP range that belongs to the network segment that will provide PXE services. + +So, after you have configured your static IP Address, updated your system and performed other initial settings, use the following command to install **DNSMASQ** daemon. + + # yum install dnsmasq + +![Install dnsmasq Package](http://www.tecmint.com/wp-content/uploads/2014/10/Install-dnsmasq-in-CentOS.jpg) +Install dnsmasq Package + +**2.** DNSMASQ main default configuration file located in **/etc** directory is self-explanatory but intends to be quite difficult to edit, do to its highly commented explanations. + +First make sure you backup this file in case you need to review it later and, then, create a new blank configuration file using your favorite text editor by issuing the following commands. + + # mv /etc/dnsmasq.conf /etc/dnsmasq.conf.backup + # nano /etc/dnsmasq.conf + +**3.** Now, copy and paste the following configurations on **dnsmasq.conf** file and assure that you change the below explained statements to match your network settings accordingly. + + interface=eno16777736,lo + #bind-interfaces + domain=centos7.lan + # DHCP range-leases + dhcp-range= eno16777736,192.168.1.3,192.168.1.253,255.255.255.0,1h + # PXE + dhcp-boot=pxelinux.0,pxeserver,192.168.1.20 + # Gateway + dhcp-option=3,192.168.1.1 + # DNS + dhcp-option=6,92.168.1.1, 8.8.8.8 + server=8.8.4.4 + # Broadcast Address + dhcp-option=28,10.0.0.255 + # NTP Server + dhcp-option=42,0.0.0.0 + + pxe-prompt="Press F8 for menu.", 60 + pxe-service=x86PC, "Install CentOS 7 from network server 192.168.1.20", pxelinux + enable-tftp + tftp-root=/var/lib/tftpboot + +![Dnsmasq Configuration](http://www.tecmint.com/wp-content/uploads/2014/10/dnsmasq-configuration.jpg) +Dnsmasq Configuration + +The statements that you need to change are follows: + +- **interface** – Interfaces that the server should listen and provide services. +- **bind-interfaces** – Uncomment to bind only on this interface. +- **domain** – Replace it with your domain name. +- **dhcp-range** – Replace it with IP range defined by your network mask on this segment. +- **dhcp-boot** – Replace the IP statement with your interface IP Address. +- **dhcp-option=3,192.168.1.1** – Replace the IP Address with your network segment Gateway. +- **dhcp-option=6,92.168.1.1** – Replace the IP Address with your DNS Server IP – several DNS IPs can be defined. +- **server=8.8.4.4** – Put your DNS forwarders IPs Addresses. +- **dhcp-option=28,10.0.0.255** – Replace the IP Address with network broadcast address –optionally. +- **dhcp-option=42,0.0.0.0** – Put your network time servers – optionally (0.0.0.0 Address is for self-reference). +- **pxe-prompt** – Leave it as default – means to hit F8 key for entering menu 60 with seconds wait time.. +- **pxe=service** – Use x86PC for 32-bit/64-bit architectures and enter a menu description prompt under string quotes. Other values types can be: PC98, IA64_EFI, Alpha, Arc_x86, Intel_Lean_Client, IA32_EFI, BC_EFI, Xscale_EFI and X86-64_EFI. +- **enable-tftp** – Enables the build-in TFTP server. +- **tftp-root** – Use /var/lib/tftpboot – the location for all netbooting files. + +For other advanced options concerning configuration file feel free to read [dnsmasq manual][6]. + +### Step 2: Install SYSLINUX Bootloaders ### + +**4.** After you have edited and saved **DNSMASQ** main configuration file, go ahead and install **Syslinx** PXE bootloader package by issuing the following command. + + # yum install syslinux + +![Install Syslinux Bootloaders](http://www.tecmint.com/wp-content/uploads/2014/10/install-syslinux-bootloaders.jpg) +Install Syslinux Bootloaders + +**5.** The PXE bootloaders files reside in **/usr/share/syslinux** absolute system path, so you can check it by listing this path content. This step is optional, but you might need to be aware of this path because on the next step, we will copy of all its content to **TFTP Server** path. + + # ls /usr/share/syslinux + +![Syslinux Files](http://www.tecmint.com/wp-content/uploads/2014/10/syslinux-files.jpg) +Syslinux Files + +### Step 3: Install TFTP-Server and Populate it with SYSLINUX Bootloaders ### + +**6.** Now, let’s move to next step and install **TFTP-Server** and, then, copy all bootloders files provided by Syslinux package from the above listed location to **/var/lib/tftpboot** path by issuing the following commands. + + # yum install tftp-server + # cp -r /usr/share/syslinux/* /var/lib/tftpboot + +![Install TFTP Server](http://www.tecmint.com/wp-content/uploads/2014/10/install-tftp-server.jpg) +Install TFTP Server + +### Step 4: Setup PXE Server Configuration File ### + +**7.** Typically the **PXE Server** reads its configuration from a group of specific files (**GUID** files – first, **MAC** files – next, **Default** file – last) hosted in a folder called **pxelinux.cfg**, which must be located in the directory specified in **tftp-root** statement from DNSMASQ main configuration file. + +Create the required directory **pxelinux.cfg** and populate it with a **default** file by issuing the following commands. + + # mkdir /var/lib/tftpboot/pxelinux.cfg + # touch /var/lib/tftpboot/pxelinux.cfg/default + +**8.** Now it’s time to edit **PXE Server** configuration file with valid Linux distributions installation options. Also note that all paths used in this file must be relative to the **/var/lib/tftpboot** directory. + +Below you can see an example configuration file that you can use it, but modify the installation images (kernel and initrd files), protocols (FTP, HTTP, HTTPS, NFS) and IPs to reflect your network installation source repositories and paths accordingly. + + # nano /var/lib/tftpboot/pxelinux.cfg/default + +Add the following whole excerpt to the file. + + default menu.c32 + prompt 0 + timeout 300 + ONTIMEOUT local + + menu title ########## PXE Boot Menu ########## + + label 1 + menu label ^1) Install CentOS 7 x64 with Local Repo + kernel centos7/vmlinuz + append initrd=centos7/initrd.img method=ftp://192.168.1.20/pub devfs=nomount + + label 2 + menu label ^2) Install CentOS 7 x64 with http://mirror.centos.org Repo + kernel centos7/vmlinuz + append initrd=centos7/initrd.img method=http://mirror.centos.org/centos/7/os/x86_64/ devfs=nomount ip=dhcp + + label 3 + menu label ^3) Install CentOS 7 x64 with Local Repo using VNC + kernel centos7/vmlinuz + append initrd=centos7/initrd.img method=ftp://192.168.1.20/pub devfs=nomount inst.vnc inst.vncpassword=password + + label 4 + menu label ^4) Boot from local drive + +![Configure PXE Server](http://www.tecmint.com/wp-content/uploads/2014/10/configure-pxe-server.jpg) +Configure PXE Server + +As you can see CentOS 7 boot images (kernel and initrd) reside in a directory named **centos7** relative to **/var/lib/tftpboot** (on an absolute system path this would mean **/var/lib/tftpboot/centos7**) and the installer repositories can be reached by using FTP protocol on **192.168.1.20/pub** network location – in this case the repos are hosted locally because the IP address is the same as the PXE server address). + +Also menu **label 3** specifies that the client installation should be done from a remote location via **VNC** (here replace VNC password with a strong password) in case you install on a headless client and the menu **label 2** specifies as installation sources a CentOS 7 official Internet mirror (this case requires an Internet connection available on client through DHCP and NAT). + +**Important**: As you see in the above configuration, we’ve used CentOS 7 for demonstration purpose, but you can also define RHEL 7 images, and following whole instructions and configurations are based on CentOS 7 only, so be careful while choosing distribution. + +### Step 5: Add CentOS 7 Boot Images to PXE Server ### + +**9.** For this step CentOS kernel and initrd files are required. To get those files you need the **CentOS 7 DVD ISO** Image. So, go ahead and download CentOS DVD Image, put it in your DVD drive and mount the image to **/mnt** system path by issuing the below command. + +The reason for using the DVD and not a Minimal CD Image is the fact that later this DVD content would be used to create the locally installer repositories for **FTP** sources. + + # mount -o loop /dev/cdrom /mnt + # ls /mnt + +![Mount CentOS DVD](http://www.tecmint.com/wp-content/uploads/2014/10/mount-centos-dvd.jpg) +Mount CentOS DVD + +If your machine has no DVD drive you can also download **CentOS 7 DVD ISO** locally using **wget** or **curl** utilities from a [CentOS mirror][7] and mount it. + + # wget http://mirrors.xservers.ro/centos/7.0.1406/isos/x86_64/CentOS-7.0-1406-x86_64-DVD.iso + # mount -o loop /path/to/centos-dvd.iso /mnt + +**10.** After the DVD content is made available, create the **centos7** directory and copy CentOS 7 bootable kernel and initrd images from the DVD mounted location to centos7 folder structure. + + # mkdir /var/lib/tftpboot/centos7 + # cp /mnt/images/pxeboot/vmlinuz /var/lib/tftpboot/centos7 + # cp /mnt/images/pxeboot/initrd.img /var/lib/tftpboot/centos7 + +![Copy CentOS Bootable Files](http://www.tecmint.com/wp-content/uploads/2014/10/copy-centos-bootable-files.jpg) +Copy CentOS Bootable Files + +The reason for using this approach is that, later you can create new separate directories in **/var/lib/tftpboot** path and add other Linux distributions to PXE menu without messing up the entire directory structure. + +### Step 6: Create CentOS 7 Local Mirror Installation Source ### + +**11.** Although you can setup **Installation Source Mirrors** via a variety of protocols such as HTTP, HTTPS or NFS, for this guide, I have chosen **FTP** protocol because is very reliable and easy to setup with the help of **vsftpd** server. + +Further install vsftpd daemon, copy all DVD mounted content to **vsftpd** default server path (**/var/ftp/pub**) – this can take a while depending on your system resources and append readable permissions to this path by issuing the following commands. + + # yum install vsftpd + # cp -r /mnt/* /var/ftp/pub/ + # chmod -R 755 /var/ftp/pub + +![Install Vsftpd Server](http://www.tecmint.com/wp-content/uploads/2014/10/install-vsftpd-in-centos.jpg) +Install Vsftpd Server + +![Copy Files to FTP Path](http://www.tecmint.com/wp-content/uploads/2014/10/copy-files-to-ftp-path.jpg) +Copy Files to FTP Path + +![Set Permissions on FTP Path](http://www.tecmint.com/wp-content/uploads/2014/10/set-permission-on-ftp-path.jpg) +Set Permissions on FTP Path + +### Step 7: Start and Enable Daemons System-Wide ### + +**12.** Now that the PXE server configuration is finally finished, start **DNSMASQ** and **VSFTPD** servers, verify their status and enable it system-wide, to automatically start after every system reboot, by running the below commands. + + # systemctl start dnsmasq + # systemctl status dnsmasq + # systemctl start vsftpd + # systemctl status vsftpd + # systemctl enable dnsmasq + # systemctl enable vsftpd + +![Start Dnsmasq Service](http://www.tecmint.com/wp-content/uploads/2014/10/start-dnsmasq.jpg) +Start Dnsmasq Service + +![Start Vsftpd Service](http://www.tecmint.com/wp-content/uploads/2014/10/start-vsftpd.jpg) +Start Vsftpd Service + +### Step 8: Open Firewall and Test FTP Installation Source ### + +**13.** To get a list of all ports that needs to be open on your Firewall in order for client machines to reach and boot from PXE server, run **netstat** command and add CentOS 7 Firewalld rules accordingly to dnsmasq and vsftpd listening ports. + + # netstat -tulpn + # firewall-cmd --add-service=ftp --permanent ## Port 21 + # firewall-cmd --add-service=dns --permanent ## Port 53 + # firewall-cmd --add-service=dhcp --permanent ## Port 67 + # firewall-cmd --add-port=69/udp --permanent ## Port for TFTP + # firewall-cmd --add-port=4011/udp --permanent ## Port for ProxyDHCP + # firewall-cmd --reload ## Apply rules + +![Check Listening Ports](http://www.tecmint.com/wp-content/uploads/2014/10/check-listening-ports.jpg) +Check Listening Ports + +![Open Ports in Firewall](http://www.tecmint.com/wp-content/uploads/2014/10/open-ports-on-firewall.jpg) +Open Ports in Firewall + +**14.** To test FTP Installation Source network path open a browser locally ([**lynx**][8] should do it) or on a different computer and type the IP Address of your PXE server with FTP protocol followed by **/pub** network location on URL filed and the result should be as presented in the below screenshot. + + ftp://192.168.1.20/pub + +![Access FTP Files via Browser](http://www.tecmint.com/wp-content/uploads/2014/10/browse-ftp-files.jpg) +Access FTP Files via Browser + +**15.** To debug PXE server for eventual misconfigurations or other information and diagnostics in live mode run the following command. + + # tailf /var/log/messages + +![Check PXE Logs for Errors](http://www.tecmint.com/wp-content/uploads/2014/10/check-pxe-errors.jpg) +Check PXE Logs for Errors + +**16.** Finally, the last required step that you need to do is to unmount CentOS 7 DVD and remove the physical medium. + + # umount /mnt + +### Step 9: Configure Clients to Boot from Network ### + +**17.** Now your clients can boot and install CentOS 7 on their machines by configuring Network Boot as **primary boot device** from their systems BIOS or by hitting a specified key during **BIOS POST** operations as specified in motherboard manual. + +In order to choose network booting. After first PXE prompt appears, press **F8** key to enter presentation and then hit **Enter** key to proceed forward to PXE menu. + +![PXE Network Boot](http://www.tecmint.com/wp-content/uploads/2014/10/pxe-network-boot.jpg) +PXE Network Boot + +![PXE Network OS Boot](http://www.tecmint.com/wp-content/uploads/2014/10/pxe-network-os-boot.jpg) +PXE Network OS Boot + +**18.** Once you have reached PXE menu, choose your CentOS 7 installation type, hit **Enter** key and continue with the installation procedure the same way as you might install it from a local media boot device. + +Please note down that using variant 2 from this menu requires an active Internet connection on the target client. Also, on below screenshots you can see an example of a client remote installation via VNC. + +![PXE Menu](http://www.tecmint.com/wp-content/uploads/2014/10/pxe-menu.jpg) +PXE Menu + +![Remote Linux Installation via VNC](http://www.tecmint.com/wp-content/uploads/2014/10/os-installation-via-vnc.jpg) +Remote Linux Installation via VNC + +![Remote Installation of CentOS](http://www.tecmint.com/wp-content/uploads/2014/10/remote-centos-installation.jpg) +Remote Installation of CentOS + +That’s all for setting up a minimal **PXE Server** on **CentOS 7**. On my next article from this series, I will discuss other issues concerning this PXE server configuration such as how to setup automated installations of **CentOS 7** using **Kickstart** files and adding other Linux distributions to PXE menu – **Ubuntu Server** and **Debian 7**. + +-------------------------------------------------------------------------------- + +via: http://www.tecmint.com/install-pxe-network-boot-server-in-centos-7/ + +作者:[Matei Cezar][a] +译者:[译者ID](https://github.com/译者ID) +校对:[校对者ID](https://github.com/校对者ID) + +本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出 + +[a]:http://www.tecmint.com/author/cezarmatei/ +[1]:http://www.tecmint.com/centos-7-installation/ +[2]:http://www.tecmint.com/redhat-enterprise-linux-7-installation/ +[3]:http://www.tecmint.com/configure-network-interface-in-rhel-centos-7-0/ +[4]:http://www.tecmint.com/remove-unwanted-services-in-centos-7/ +[5]:http://www.tecmint.com/install-ntp-server-in-centos/ +[6]:http://www.thekelleys.org.uk/dnsmasq/docs/dnsmasq-man.html +[7]:http://isoredirect.centos.org/centos/7/isos/x86_64/ +[8]:http://www.tecmint.com/command-line-web-browsers/ \ No newline at end of file