当前位置: 首页 > news >正文

Linux下PXE服务器搭建

Linux下搭建PXE服务器
《PXE服务器搭建全指南:从原理到实战部署》

传统硬盘启动如同马车运输,PXE则是信息时代的高速铁路

前言

PXE(预启动执行环境)是由Intel设计的革命性协议,它使计算机能够不依赖本地存储设备直接从网络启动操作系统。这种网络启动技术正在企业IT环境中扮演着越来越重要的角色。


一、探秘PXE

1. PXE的用途

  • 批量部署系统:同时为数十台机器安装操作系统
  • 无盘工作站:网吧、实验室等场景的理想解决方案
  • 紧急救援:当本地系统崩溃时,从网络恢复
  • 集中化管理:统一控制所有机器的启动环境

2. 工作原理

2.1 PXE启动步骤

  • DHCP分配IP:客户端发出"我是谁"的询问
  • TFTP传送引导:获取引导文件(pxelinux.0)
  • HTTP加载内核:下载操作系统的"灵魂"(vmlinuz)
  • 完成启动
ClientDHCPTFTPHTTP1. 请求IP地址2. 分配IP3. 获取引导文件4. 发送pxelinux.05. 下载系统镜像6. 完成系统安装ClientDHCPTFTPHTTP

2.2 核心组件解析

  • DHCP服务器:IP地址分配与引导定位
  • TFTP服务器:轻量级文件传输
  • HTTP/NFS服务器:系统镜像分发
  • SYSLINUX:引导加载程序集

二、基础环境准备

1. 服务管理

# 关闭防火墙
systemctl stop firewalld
systemctl disable firewalld  
systemctl status firewalld

2 软件安装

# 安装核心组件
yum install -y dhcp tftp-server xinetd httpd syslinux

三、服务配置详解

1. DHCP配置

# 安装DHCP服务
yum install dhcp -y# 编辑配置文件
vi /etc/dhcp/dhcpd.conf

配置文件核心内容

# /etc/dhcp/dhcpd.conf 关键配置
subnet 192.168.2.0 netmask 255.255.255.0 { #定义子网网段和掩码
range 192.168.2.30 192.168.2.254; #子网IP地址范围
option domain-name-servers 8.8.8.8,8.8.4.4; #子网DNS
option domain-name "internal.example.org"; #子网域名
option routers 192.168.2.1; #子网网关
option broadcast-address 192.168.2.255; #子网广播地址
default-lease-time 3600 ; #默认租约时间,单位为s
max-lease-time 7200; #最大的租约时间,单位为s
next-server 192.168.2.11; #pxe服务器的ip
#filename "pxelinux.0"; #pxe服务器引导文件,legacy模式
filename "bootx64.efi"; #efi模式为bootx64.efi

启动服务并开机自启

systemctl restart dhcpd
systemctl enable dhcpd
systemctl status dhcpd
systemctl is-enabled dhcpd

2. 配置TFTP服务

# 安装必要组件
yum install -y tftp tftp-server xinetd# 配置TFTP服务
vi /etc/xinetd.d/tftp

配置文件内容
把disable参数修改为no

service tftp
{ socket_type =dgram
protocol =udp
wait =yes
user =root
server =/usr/sbin/in.tftpd
server_args =-s /home/mike/tftpboot -c
disable =no
per_source =11
cps =100 2
flags =IPv4
}

重启tftp服务并开机自启

systemctl restart tftp.socket
systemctl enable tftp.socket
systemctl status tftp.socket
systemctl is-enabled tftp.socket
systemctl restart tftp.service
systemctl enable tftp.service
systemctl status tftp.service
systemctl is-enabled tftp.service
systemctl restart xinetd
systemctl enable xinetd
systemctl status xinetd
systemctl is-enabled xinetd

3. 配置HTTP服务

# 安装Apache
yum install -y httpd# 创建镜像目录
mkdir /var/www/html/RHEL# 挂载系统镜像
mount -o loop /root/rhel-server-7.8-x86_64-dvd.iso /var/www/html/RHEL# 启动服务
systemctl start httpd

4. 配置引导文件

4.1 Legacy模式:经典启动方式

# 安装Syslinux
yum install -y syslinux# 复制引导文件
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
cp /var/www/html/Rhel/images/pxeboot/{vmlinuz,initrd.img} /var/lib/tftpboot/
cp /var/www/html/Rhel/isolinux/{vesamenu.c32,boot.msg,splash.png} /var/lib/tftpboot/  
cp /usr/share/syslinux/{chain.c32,mboot.c32,menu.c32,memdisk} /var/lib/tftpboot/# 创建配置目录  
mkdir /var/lib/tftpboot/pxelinux.cfg# 复制配置文件
cp /var/www/html/Rhel/isolinux/isolinux.cfg /var/li

修改default文件

vim /var/lib/tftpboot/pxelinux.cfg/default
default linux
label linux
kernel vmlinuz
append initrd=initrd.img inst.repo=http://192.168.2.11/Rhel7.8 devfs=nomount ip=dhcp

4.2 UEFI模式:现代启动方式

# 复制核心文件
cp /var/www/html/Rhel/images/pxeboot/{vmlinuz,initrd.img} /var/lib/tftpboot/
cp /var/www/html/Rhel/isolinux/{vesamenu.c32,boot.msg,splash.png} /var/lib/tftpboot/  
cp /usr/share/syslinux/{chain.c32,mboot.c32,menu.c32,memdisk} /var/lib/tftpboot/# 制作EFI引导文件
yum -y install grub2-efi-modules
grub2-mkstandalone -d /usr/lib/grub/x86_64-efi/ -O x86_64-efi --modules="tftp net efinet linux part_gpt efifwsetup" -o bootx64.efi# 复制配置文件
cp bootx64.efi /var/lib/tftpboot/
cp /var/www/html/Rhel/EFI/BOOT/grub.cfg /var/lib/tftpboot/

修改grub.cfg:

vim /var/lib/tftpboot/grub.cfg
Linuxefi (tftp)/vmlinuz inst.repo=http://192.168.2.11/Rhel7.8/
initrdefi (tftp)/initrd.img

四、启动验证

当一切配置完成,重启DHCP服务:

systemctl restart dhcpd

现在,连接同一网络的客户端即可实现:

  • 设置BIOS/UEFI为网络启动优先
  • 自动获取IP地址
  • 加载引导菜单
  • 开始操作系统安装

在这里插入图片描述

http://www.lryc.cn/news/610384.html

相关文章:

  • EdgeView for macOS:解决图像管理痛点的利器
  • 【BUUCTF系列】[极客大挑战 2019]LoveSQL 1
  • Scrapy爬虫集成MongoDB存储
  • FinalShell 跳板机proxyjump使用
  • Go 与 Python 爬虫代码实操对比
  • Python接口自动化测试之之request
  • SpringMvc跨域配置方法详解
  • Jmeter进行性能并发测试
  • 设计模式-创建型-工厂模式
  • Clion STM32CubeMX LED闪灯
  • CentOS卸载、安装MySQL8(yum操作)
  • 【QT】常⽤控件详解(三)常用按钮控件PushButton RadioButton CheckButton Tool Button
  • Kali基础知识点【2】
  • 查看 Java 字节码文件:jclasslib 的使用
  • C++高频知识点(十四)
  • 文件包含篇
  • Linux中netstat详细使用指南
  • MySQL偏门但基础的面试题集锦
  • webm 读取解析
  • 并发编程常用工具类(上):CountDownLatch 与 Semaphore 的协作应用
  • Linux 使用 firewalld :开放端口与常用操作指南
  • 【机器学习】(算法优化二)提升算法之:AdaBoost与随机梯度
  • C++多线程同步:深入理解互斥量与事件机制
  • 【node】token的生成与解析配置
  • 笔试——Day28
  • 我用一个 Postgres 实现一整套后端架构!
  • LeetCode 分类刷题:16. 最接近的三数之和
  • 【Unity】协程 Async
  • 体育数据创业:用 API + 比分网,低成本快速验证
  • Mirror学习笔记