设为首页 收藏本站
查看: 650|回复: 0

[经验分享] DHCP+VSFTPD+TFTP+Kickstart搭建PXE环境实现批量自动化系统安装

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-9-20 10:35:58 | 显示全部楼层 |阅读模式
一、简介
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 文件
[iyunv@server100 ~]# yum install system-config-kickstart.noarch -y
[iyunv@server100 ~]# system-config-kickstart

wKiom1ffaxLAQGxBAAC_CB20cuY866.jpg

wKioL1ffaxuDYTZ0AADdSHHBkcA165.jpg

wKiom1ffaxqyUtgeAADld6liJYA763.jpg

wKioL1ffaxeh1QhVAACen0c_Ohw744.jpg
wKiom1ffaxjSR-uHAACfIE1DiAE037.jpg
wKioL1ffaxmAHNUzAACg-dQFDCs592.jpg

wKiom1ffaxfSbvGXAADuQQN22Qc647.jpg
wKioL1ffaxWzlioqAAB0Sh19fjk942.jpg



wKiom1ffaxSQODVTAADs_5JHzmg820.jpg
wKiom1ffaxXwukDQAADtyYN7cHE733.jpg

wKioL1ffaxLQEqs4AACOMYozDwY299.jpg
wKioL1ffaxPD01W4AAAAhFGBj1M350.jpg


2.2、配置vsftpd安装方式
[iyunv@server100 ~]# yum install   vsftpd -y
[iyunv@server100 ~]# mkdir /var/ftp/pub/yumsource6.5
[iyunv@server100 ~]# mount /dev/cdrom /var/ftp/pub/yumsource6.5
[iyunv@server100 ~]# cd /var/ftp/pub/
[iyunv@server100 pub]# ls
ks.cfg  yumsource6.5

wKioL1ffcyCCAxOqAAC4OeVUVK0043.jpg


2.3、配置TFTP

[iyunv@server100 ~]# yum install tftp-server  vsftpd -y
[iyunv@server100 ~]# /etc/init.d/vsftpd  start
[iyunv@server100 ~]# vim /etc/xinetd.d/tftp
        disable                 = no
[iyunv@server100 ~]# /etc/init.d/xinetd restart

2.4、配置DHCP
[iyunv@server100 ~]# yum install dhcp -y
[iyunv@server100 ~]# cp -p /usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample /etc/dhcp/dhcpd.conf
[iyunv@server100 ~]# vim /etc/dhcp/dhcpd.conf
  • option domain-name "server100.example.com";
  • option domain-name-servers 172.25.254.6;

  • default-lease-time 60;
  • max-lease-time 7200;
  • log-facility local7;

  • 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;
  • }

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

2.5、配置支持PXE的启动程序
[iyunv@server100 pub]# cd /var/ftp/pub/yumsource6.5/
[iyunv@server100 yumsource6.5]# cp -r isolinux/*  /var/lib/tftpboot/
[iyunv@server100 yumsource6.5]# yum install syslinux -y
[iyunv@server100 yumsource6.5]# cp /usr/share/syslinux/pxelinux.0  /var/lib/tftpboot/
[iyunv@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";
}
[iyunv@server100 tftpboot]# mkdir pxelinux.cfg
[iyunv@server100 tftpboot]# cp isolinux.cfg pxelinux.cfg/default
[iyunv@server100 tftpboot]# /etc/init.d/dhcpd restart
[iyunv@server100 tftpboot]# chmod 777 pxelinux.cfg/default
[iyunv@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
[iyunv@server100 tftpboot]# /etc/init.d/dhcpd restart
[iyunv@server100 pub]# /etc/init.d/vsftpd restart
[iyunv@server100 pub]# /etc/init.d/xinetd  restart

三、测试安装

wKiom1fft7KBu5c2AAD8zsZrh-M843.jpg

wKioL1fft4ahNixEAAB1J8RDDqQ172.jpg

wKioL1fft5aDUsESAAB4p2sIerA706.jpg

wKiom1fft6WxchOjAABdQOjYUdk864.jpg


开始安装:

wKioL1ffuGKR0fkAAAAmqa1yklM743.jpg wKiom1ffuGLxZCDRAAMaobNA-lA216.jpg

wKioL1ffuNvQFYmRAAAd68AGuHU098.jpg

wKioL1ffuNvjxjo0AAAEqlXVAWc118.jpg

wKiom1ffuNuS9Q98AAAhRj_mIiQ234.jpg

wKioL1ffuNqQo0JpAABpHp7OlRE553.jpg

wKiom1ffujWToBsoAACHCYZBYAw614.jpg

wKioL1ffujuQoU54AAnxmNlqsgQ487.jpg





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-274850-1-1.html 上篇帖子: SELinux安全策略的设置及应用 下篇帖子: Linux下查看网卡流量
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表