目录

前言

PXE(preboot execute environment预启动执行环境 ),支持Client通过网络从Server下载映像,并由此支持通过网络启动操作系统,在启动过程中,Client要求Server分配IP地址,再用TFTP(trivial file transfer protocol)或MTFTP(multicast trivial file transfer protocol)协议下载一个启动软件包到Client内存中执行,由这个启动软件包完成Client上的基本软件设置,从而引导预先安装在Sserver上的操作系统,即”推机”。本篇介绍在RHEL7上的PXE服务器搭建。

PXE原理

1、Client首先要获取 IP(进行网络连接)

PXEserver中要含有DHCPservice,为Client提供p-netmask-gw-dns。

2、Client想要得到安装界面,PXEserver必须为其提供系统引导

Client从PXEserver中获得 pxelinux.0(实际上就是 grub)、vmlinuz(内核文件),initrd(内存驱动盘)这3个文件。先通过引导 grub,再加载其余2个文件来实现Client的系统引导。

3、通过TFTPserver以广播的形式发送系统引导所需要的3个文件给Client

PXEserver告知TFTPserver Client的IP,再由TFTPserver将系统引导的3个文件发送给Client。

4、TFTPserver共享Client安装系统所需要的软件包

通过FTP(RHEL6)、HTTP(RHEL7)、 nfs(RHEL5)等服务实现C\S之间的文件共享。

4、安装系统时设置Hostname :如果没有设置Client的hostname,默认为localhost.localdomain。若想给每个Client都设置唯一的hostname,需要DNSserver,再利用DNSserver的反向解析,为Client分配Hostname。

5、批量部署:使用 Kickstart无人值守服务批量部署服务器。

总结:PXE服务器需要提供下列服务

(1)DHCP

(2)TFTP

(3)FTP|HTTP|NFS

(4)DNS

(5)Kickstart

下面几种不同OS平台上的部署方案均使用了Kickstart无人值守服务:

1)Sattlle

2)RH401 卫星服务器(walkspace centos)

3)windows WDS

搭建PXE服务器

本篇的实验是搭建all-in-one的PXE服务器,即将上述所有的服务搭建在用一台服务器上。

关闭SELinux和防火墙

setenforce 0
systemctl stop firewalld.service
systemctl mask iptables.service
systemctl mask ebtables.service

配置DHCP

安装DHCP软件包

yum install dhcp  

编辑DHCP服务配置文件

Copy模版得到配置文件

cat /usr/share/doc/dhcp*/dhcpd.conf.example > /etc/dhcp/dhcpd.conf

vim /etc/dhcp/dhcpd.conf

log-facility local7;
subnet 192.168.0.0 netmask 255.255.255.0 {
range 192.168.0.10 192.168.0.100;
option domain-name-servers 192.168.0.1;
option domain-name "fan.com";
option routers 192.168.0.1;
next-server 192.168.0.1; #指定TFTPserver ip,现在为本机IP
filename "/pxelinux.0"; #此"/"指的是TFTP共享的根目录/var/lib/tftpboot下
option broadcast-address 192.168.0.255;
default-lease-time 600;
max-lease-time 7200;
}

重启DHCP服务加载配置

systemctl  restart dhcpd
netstat -anplut |grep dhcp
systemctl enable dhcpd.service

配置TFTP

安装TFTP软件包

 yum install tftp-server

安装syslinux软件包

获取pxelinux.0文件

cd /var/lib/tftpboot         #TFTP共享跟目录
yum install syslinux
rpm -ql syslinux | grep pxelinux.0 #查询软件包文件的安装位置
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot

从OS光盘中获取initrd.img、vmlinuz文件

mount /dev/cdrom /mnt/cdrom
cd /mnt/cdrom/images/pxeboot
cp initrd.img vmlinuz /var/lib/tftpboot

获取pxelinux的配置文件

在推机的过程中,Pxelinux会以IP地址的16进制表示来搜索配置文件,如果没找到,就去除最低一位数后继续找。如果所有匹配都失败,就使用default文件。

mkdir /var/lib/tftpboot/pxelinux.cfg
cp /mnt/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
chmod u+w /var/lib/tftpboot/pxelinux.cfg/default
cp /mnt/isolinux/boot.msg /var/lib/tftpboot/ #引导图片
chmod u+w /var/lib/tftpboot/boot.msg

编辑pxelinux的配置文件

vim /var/lib/tftpboot/pxelinux.cfg/default

default linux    #第一个label改为linux

append    #扩充无人值守功能
initrd=initrd.img inst.repo=ftp://192.168.0.1/cdrom ks=ftp://192.168.0.1/ks.cfg quiet #指定无人值守文件ks.cfg

编辑TFTP服务配置文件

vim /etc/xinetd.d/tftp

disable=no 

重启TFTP :

systemctl restart xinetd.service
netstat -anplut | grep :69 #检查xinetd服务是否启动

配置FTP

将OS光盘中的软件包共享给Client。

安装vsftpd软件包

yum install vsftpd

挂载光盘到FTP跟目录下

mkdir /var/ftp/cdrom
mount /dev/cdrom /var/ftp/cdrom

重启FTP服务

systemctl restart vsftpd
systemctl enable vsftpd

配置Kickstart

使用用图形化界面system-config-kickstart 建立自动应答Kickstart文件。

安装图形化界面

yum install system-config-kickstart

再次编辑Kickstart无人值守文件

vim /root/ks.cfg

加入你未来部署系统的软件包(%packages 软件包名 %end)

通过FTP服务共享ks.cfg文件

cp /root/ks.cfg /var/ftp
systemctl restart xinetd.service

Jmilk

Linux_PXE服务器_RHEL7的更多相关文章

  1. App开发:模拟服务器数据接口 - MockApi

    为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...

  2. 闰秒导致MySQL服务器的CPU sys过高

    今天,有个哥们碰到一个问题,他有一个从库,只要是启动MySQL,CPU使用率就非常高,其中sys占比也比较高,具体可见下图. 注意:他的生产环境是物理机,单个CPU,4个Core. 于是,他抓取了CP ...

  3. 闲来无聊,研究一下Web服务器 的源程序

    web服务器是如何工作的 1989年的夏天,蒂姆.博纳斯-李开发了世界上第一个web服务器和web客户机.这个浏览器程序是一个简单的电话号码查询软件.最初的web服务器程序就是一个利用浏览器和web服 ...

  4. SignalR系列续集[系列8:SignalR的性能监测与服务器的负载测试]

    目录 SignalR系列目录 前言 也是好久没写博客了,近期确实很忙,嗯..几个项目..头要炸..今天忙里偷闲.继续我们的小系列.. 先谢谢大家的支持.. 我们来聊聊SignalR的性能监测与服务器的 ...

  5. 使用 Nodejs 搭建简单的Web服务器

    使用Nodejs搭建Web服务器是学习Node.js比较全面的入门教程,因为要完成一个简单的Web服务器,你需要学习Nodejs中几个比较重要的模块,比如:http协议模块.文件系统.url解析模块. ...

  6. 通过ProGet搭建一个内部的Nuget服务器

    .NET Core项目完全使用Nuget 管理组件之间的依赖关系,Nuget已经成为.NET 生态系统中不可或缺的一个组件,从项目角度,将项目中各种组件的引用统统交给NuGet,添加组件/删除组件/以 ...

  7. 谈谈如何使用Netty开发实现高性能的RPC服务器

    RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协议.说的再直白一点,就是客户端在不必知道 ...

  8. 游戏服务器菜鸟之C#初探一游戏服务

    本人80后程序猿一枚,原来搞过C++/Java/C#,因为工作原因最后选择一直从事C#开发,因为读书时候对游戏一直比较感兴趣,机缘巧合公司做一个手游的项目,我就开始游戏服务器的折腾之旅. 游戏的构架是 ...

  9. 无法向会话状态服务器发出会话状态请求。请确保 ASP.NET State Service (ASP.NET 状态服务)已启动,并且客户端端口与服务器端口相同。如果服务器位于远程计算机上,请检查。。。

    异常处理汇总-服 务 器 http://www.cnblogs.com/dunitian/p/4522983.html 无法向会话状态服务器发出会话状态请求.请确保 ASP.NET State Ser ...

随机推荐

  1. 搭建docker+k8s踩过的坑

    问题一: # yum install -y etcd kubernetes Error: docker-ce-cli conflicts with :docker--.gitb2f74b2.el7.c ...

  2. Linux磁盘分区与lvm逻辑卷

    硬盘接口的种类分四类:(价格由低到高) IDE SATA硬盘:别名串口硬盘,具有较强的纠错能力. SCSI硬盘:即采用SCSI接口的硬盘,SCSI接口具有应用范围广,多任务,带宽大,CPU占用率低. ...

  3. [工具] BurpSuite--Intruder功能

    BurpSuite--Intruder功能 0x00 配置说明 intruder是进行爆破的,基本流程是标注请求的爆破参数,然后配置字段,选择爆破方式进行爆破,下面来记录下工具的使用 选中intrud ...

  4. mysql主从库配置读写分离以及备份

    1,什么是读写分离?其实就是将数据库分为了主从库,一个主库用于写数据,多个从库完成读数据的操作,主从库之间通过某种机制进行数据的同步,是一种常见的数据库架构.一个组从同步集群,通常被称为是一个“分组” ...

  5. 移动端ios和安卓input问题

    在钉钉开发微应用的时候. 安卓和苹果输入input框的时候.失去焦点和获取焦点会有明显的上下跳动 因此我用绝对定位把位置固定在一个地方.就不会有跳动

  6. MySQL——Alias

    查询时,当表名很长或者执行一些特殊查询的时候,为了方便操作或者需要多次使用相同的表时,可以为表指定别名,用这个别名代替表原来的名称. 设置别名为表设置别名 <表名> [AS] <别名 ...

  7. Hadoop2.7.4 yarn(HA)集群搭建步骤(CentOS7)

    群节点分配: Park01:Zookeeper.NameNode(active).ResourceManager(active) Park02:Zookeeper.NameNode(standby) ...

  8. 策略模式------《Head First 设计模式》

    第一章---策略模式 xzmxddx 学习方式:书籍<Head First 设计模式>,这本书通俗易懂,所有知识点全部取自本书. 面向对象设计原则 封装变化 多用组合,少用继承 针对接口编 ...

  9. 在Linux下使用命令行打印文件

    近期需要将数学笔记打印出来复习,才发现Linux KDE环境下的默认PDF软件Okular根本无法将我在GoodNotes B5大小的页面写下的内容自适应地放大到A4纸上,只能以页面的原始尺寸打印.然 ...

  10. python中pip相关命令

    用pip安装第三方包的命令 pip install xxx --user 用pip更新第三方包 pip install --upgrade xxx --user 用pip卸载第三方包 pip unin ...