DHCP+VSFTPD+TFTP+Kickstart搭建PXE环境实现批量自动化系统安装

简介:

一、简介

1.1 什么是PXE

        PXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服 务器下载映像,并由此支持通过网络启动操作系统,在启动过程中,终端要求服务器分配IP地址,再用TFTP(trivial file transfer protocol)或MTFTP(multicast trivial file transfer protocol)协议下载一个启动软件包到本机内存中执行,由这个启动软件包完成终端基本软件设置,从而引导预先安装在服务器中的终端操作系统。

        严格来说,PXE 并不是一种安装方式,而是一种引导方式。进行 PXE 安装的必要条件是在要安装的计算机中必须包含一个 PXE 支持的网卡(NIC),即网卡中必须要有 PXE Client。PXE 协议可以使计算机通过网络启动。此协议分为 Client端和 Server 端,而PXE Client则在网卡的 ROM 中。当计算机引导时,BIOS 把 PXE Client 调入内存中执行,然后由 PXE Client 将放置在远端的文件通过网络下载到本地运行。运行 PXE 协议需要设置 DHCP 服务器和 TFTP 服务器。DHCP 服务器会给 PXE Client(将要安装系统的主机)分配一个 IP 地址,由于是给 PXE Client 分配 IP 地址,所以在配置 DHCP 服务器时需要增加相应的 PXE 设置。此外,在 PXE Client 的 ROM 中,已经存在了 TFTP Client,那么它就可以通过 TFTP 协议到 TFTP Server 上下载所需的文件了。


1.2 PXE的工作过程:

1. PXE Client 从自己的PXE网卡启动,向本网络中的DHCP服务器索取IP;

2. DHCP 服务器返回分配给客户机的IP 以及PXE文件的放置位置(该文件一般是放在一台TFTP服务器上) ;

3. PXE Client 向本网络中的TFTP服务器索取pxelinux.0 文件;

4. PXE Client 取得pxelinux.0 文件后之执行该文件;

5. 根据pxelinux.0 的执行结果,通过TFTP服务器加载内核和文件系统 ;

6. 进入安装画面, 此时可以通过选择HTTP、FTP、NFS 方式之一进行安装;

详细工作流程,请参考下面这幅图


wKiom1fPSwHweQ-7AAE6VKzeTpc312.jpg


1.3什么是Kickstart

        Kickstart是一种无人值守的安装方式。它的工作原理是在安装过程中记录典型的需要人工干预填写的各种参数,并生成一个名为ks.cfg的文 件。如果在安装过程中(不只局限于生成Kickstart安装文件的机器)出现要填写参数的情况,安装程序首先会去查找Kickstart生成的文件,如 果找到合适的参数,就采用所找到的参数;如果没有找到合适的参数,便需要安装者手工干预了。所以,如果Kickstart文件涵盖了安装过程中可能出现的 所有需要填写的参数,那么安装者完全可以只告诉安装程序从何处取ks.cfg文件,然后就去忙自己的事情。等安装完毕,安装程序会根据ks.cfg中的设 置重启系统,并结束安装。

PXE+Kickstart 无人值守安装操作系统完整过程如下:

wKioL1fPSwHx-bBsAACiLfTKxO4085.jpg

二、系统环境

系统平台:RHEL7.0 (最小化安装)

系统内核:3.10.0-123.el7.x86_64

实验内容:

                    生成ks.cfg 文件

                    配置HTTP安装方式

                    配置TFTP

                    配置支持PXE的启动程序

                    配置DHCP

                    测试安装


网络模式:桥接模式

DHCP / TFTP/HTTP/NFS  IP:172.25.254.100

防火墙已关闭/iptables: Firewall is not running.

SELINUX=disabled


2.1、生成ks.cfg 文件

[root@server100 ~]# yum install system-config-kickstart.noarch -y

[root@server100 ~]# system-config-kickstart 


wKiom1ffaxLAQGxBAAC_CB20cuY866.png


wKioL1ffaxuDYTZ0AADdSHHBkcA165.png


wKiom1ffaxqyUtgeAADld6liJYA763.png

wKioL1ffaxeh1QhVAACen0c_Ohw744.png

wKiom1ffaxjSR-uHAACfIE1DiAE037.png

wKioL1ffaxmAHNUzAACg-dQFDCs592.png


wKiom1ffaxfSbvGXAADuQQN22Qc647.png

wKioL1ffaxWzlioqAAB0Sh19fjk942.png




wKiom1ffaxSQODVTAADs_5JHzmg820.png

wKiom1ffaxXwukDQAADtyYN7cHE733.png


wKioL1ffaxLQEqs4AACOMYozDwY299.png

wKioL1ffaxPD01W4AAAAhFGBj1M350.png



2.2、配置vsftpd安装方式

[root@server100 ~]# yum install   vsftpd -y

[root@server100 ~]# mkdir /var/ftp/pub/yumsource6.5

[root@server100 ~]# mount /dev/cdrom /var/ftp/pub/yumsource6.5

[root@server100 ~]# cd /var/ftp/pub/

[root@server100 pub]# ls

ks.cfg  yumsource6.5


wKioL1ffcyCCAxOqAAC4OeVUVK0043.png



2.3、配置TFTP

[root@server100 ~]# yum install tftp-server  vsftpd -y

[root@server100 ~]# /etc/init.d/vsftpd  start

[root@server100 ~]# vim /etc/xinetd.d/tftp 

        disable                 = no

[root@server100 ~]# /etc/init.d/xinetd restart


2.4、配置DHCP

[root@server100 ~]# yum install dhcp -y

[root@server100 ~]# cp -p /usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample /etc/dhcp/dhcpd.conf 

[root@server100 ~]# vim /etc/dhcp/dhcpd.conf

  1. option domain-name "server100.example.com";

  2. option domain-name-servers 172.25.254.6;


  3. default-lease-time 60;

  4. max-lease-time 7200;

  5. log-facility local7;


  6. subnet 172.25.254.0 netmask 255.255.255.0 {

  7.   range 172.25.254.66  172.25.254.88;

  8.   option routers 172.25.254.6;

  9. }

[root@server100 ~]# /etc/init.d/dhcpd start


2.5、配置支持PXE的启动程序

[root@server100 pub]# cd /var/ftp/pub/yumsource6.5/

[root@server100 yumsource6.5]# cp -r isolinux/*  /var/lib/tftpboot/

[root@server100 yumsource6.5]# yum install syslinux -y

[root@server100 yumsource6.5]# cp /usr/share/syslinux/pxelinux.0  /var/lib/tftpboot/

[root@server100 yumsource6.5]# vim /etc/dhcp/dhcpd.conf

subnet 172.25.254.0 netmask 255.255.255.0 {

  range 172.25.254.66  172.25.254.88;

  option routers 172.25.254.6;

  next-server  172.25.254.100;

  filename "pxelinux.0";

}

[root@server100 tftpboot]# mkdir pxelinux.cfg

[root@server100 tftpboot]# cp isolinux.cfg pxelinux.cfg/default

[root@server100 tftpboot]# /etc/init.d/dhcpd restart

[root@server100 tftpboot]# chmod 777 pxelinux.cfg/default

[root@server100 tftpboot]# vim pxelinux.cfg/default

timeout 60

  menu default

  kernel vmlinuz

  append initrd=initrd.img repo=ftp://172.25.254.100/pub/yumsource6.5 quiet ks=ftp://172.25.254

.100/pub/ks.cfg

[root@server100 tftpboot]# /etc/init.d/dhcpd restart

[root@server100 pub]# /etc/init.d/vsftpd restart

[root@server100 pub]# /etc/init.d/xinetd  restart


三、测试安装


wKiom1fft7KBu5c2AAD8zsZrh-M843.png


wKioL1fft4ahNixEAAB1J8RDDqQ172.png


wKioL1fft5aDUsESAAB4p2sIerA706.png


wKiom1fft6WxchOjAABdQOjYUdk864.png



开始安装:


wKioL1ffuGKR0fkAAAAmqa1yklM743.pngwKiom1ffuGLxZCDRAAMaobNA-lA216.png


wKioL1ffuNvQFYmRAAAd68AGuHU098.png


wKioL1ffuNvjxjo0AAAEqlXVAWc118.png


wKiom1ffuNuS9Q98AAAhRj_mIiQ234.png


wKioL1ffuNqQo0JpAABpHp7OlRE553.png


wKiom1ffujWToBsoAACHCYZBYAw614.png


wKioL1ffujuQoU54AAnxmNlqsgQ487.png



本文转自willis_sun 51CTO博客,原文链接:http://blog.51cto.com/willis/1854195,如需转载请自行联系原作者

相关文章
|
10月前
|
网络协议 Linux iOS开发
|
运维 网络协议 安全
pxe实现自动化部署安装高效批量网络装机
对于一个想要从事运维的人员,学会自动化部署,是一件十分便捷的事情,者可以让你的工作效率大大提高,事半功倍
pxe实现自动化部署安装高效批量网络装机
|
安全 Linux 数据安全/隐私保护
谁再说不会搭建vsftpd,就把这个脚本给他扔过去!——CentOS7下一键脚本搭建虚拟用户模式的vsftpd服务器
谁再说不会搭建vsftpd,就把这个脚本给他扔过去!——CentOS7下一键脚本搭建虚拟用户模式的vsftpd服务器
460 0
谁再说不会搭建vsftpd,就把这个脚本给他扔过去!——CentOS7下一键脚本搭建虚拟用户模式的vsftpd服务器
|
Linux
CentOS7下部署Cobbler实现PXE+Kickstart自动化安装【脚本版】
CentOS7下部署Cobbler实现PXE+Kickstart自动化安装【脚本版】
261 0
CentOS7下部署Cobbler实现PXE+Kickstart自动化安装【脚本版】
|
安全 Linux 网络安全
CentOS7下搭建vsftpd服务器(本地用户模式)
CentOS7下搭建vsftpd服务器(本地用户模式)
541 0
CentOS7下搭建vsftpd服务器(本地用户模式)
|
Linux
CentOS7下部署Cobbler实现PXE+Kickstart自动化安装
CentOS7下部署Cobbler实现PXE+Kickstart自动化安装
401 0
CentOS7下部署Cobbler实现PXE+Kickstart自动化安装
|
存储 域名解析 网络协议
Linux网络服务总结,复习看这个很方便(DHCP、FTP、SSH、DNS、NFS、PXE)
Linux网络服务总结,复习看这个很方便(DHCP、FTP、SSH、DNS、NFS、PXE)
346 0
Linux网络服务总结,复习看这个很方便(DHCP、FTP、SSH、DNS、NFS、PXE)
|
网络协议 网络安全
RH358管理DHCP和IP地址分配--自动化DHCP配置
RH358管理DHCP和IP地址分配--自动化DHCP配置
259 0
RH358管理DHCP和IP地址分配--自动化DHCP配置
|
13天前
|
机器学习/深度学习 人工智能 运维
基于AI的自动化服务器管理:解锁运维的未来
基于AI的自动化服务器管理:解锁运维的未来
64 0
|
2月前
|
机器学习/深度学习 人工智能 运维
基于AI的自动化事件响应:智慧运维新时代
基于AI的自动化事件响应:智慧运维新时代
140 11

热门文章

最新文章