本文分享自天翼云开发者社区《基于Linux系统的PXE搭建方法》,作者:t***n

一、底层环境准备

1、安装RedHat7.6系统

2、关闭防火墙和Selinux

systemctl stop firewalld

chkconfig firewalld off

vim /etc/sysconfig/selinux

修改SELINUX=disabled

3、配置本地yum源

vim /etc/yum.repos.d/rhel7.repo

[rhel7]

name=RHEL7

baseurl=file:///mnt

enabled=1

gpgcheck=0

4、安装需要的服务及软件包

yum install vsftpd tftp-server dhcp syslinux system-config-kickstart

dhcp:提供dhcp服务

vsftpd:管理本地挂在的OS完整镜像

tftp-server:使可启动镜像通过使用tftp协议网络下载

syslinux:包含网络启动所需的boot loader

system-config-kickstart:配置kickstart的图形界面的工具

5、本地物理机网络配置

vim /etc/sysconfig/network-scripts/ifcfg-eth0

TYPE=Ethernet

BOOTPROTO=static

NAME=eth0

DEVICE=eth0

ONBOOT=yes

IPADDR=192.168.64.25

NETMASK=255.255.255.0

GATEWAY=192.168.64.2

二、配置DHCP服务

vim /etc/dhcp/dhcpd.conf

添加如下:

option arch code 93 = unsigned integer 16;

allow booting;

allow bootp;

subnet 192.168.64.0 netmask 255.255.255.0 {

option routers 192.168.64.2;

range 192.168.64.100 192.168.64.200;   #分配出去的IP范围

class "pxeclients" {

match if substring (option vendor-class-identifier,0,9) = "PXEClient";

next-server 192.168.64.25;     #tftp地址,即本机PXE server IP

if option arch = 00:07 {

filename "pxelinux/BOOTX64.EFI";  #6系统UEFI模式下PXE启动时的引导文件,7系列系统还可以使用shim&grubx64.efi

}

else {

filename "pxelinux/pxelinux.0";  #Legacy模式

}

}

}

注意:启动DHCP前要配好本机网络地址信息,否则无法启动dhcpd

启动服务:

#service dhcpd start                                [ok]

#service dhcpd restart                              [ok]

三、配置tftp服务

vim /etc/xinetd.d/tftp

service tftp

{

socket_type    = dgram

protocol         = udp

wait                = yes

user                = root

server             = /usr/sbin/in.tftpd

service_args   = -s/tftpboot ###修改为引导文件的路径,本文以 /var/lib/tftpboot为例

per_xource     = 11

cps                 = 100 2

flags               =IPv4

disable           = no  ###将disable改为no

}

启动服务:

#service xinetd restart                             [ok]

四、配置PXE启动引导目录

1、将系统镜像mount或拷贝到PXE服务器上

mkdir /var/ftp/pub/RHEL7_6  ###因为用ftp搭建,所以要放在/var/ftp/文件夹中,RHEL7_6是以系统命名的,若还要其它系统可同时存在,做好区分即可

mount /dev/sr0 /mnt

cp /mnt/* /var/ftp/pub/RHEL7_6/  ###此处全copy过去,若挂载为mount /dev/sr0 /var/ftp/pub/RHEL7_6,但是mount是一次生效的,后续再用还需要mount,且安装系统过程中mount 不能中断

2、copy引导文件到/var/lib/tftpboot/pxelinux中

mkdir /var/lib/tftpboot/pxelinux/RHEL7_6  ###因为可能会做多个系统,所以在pxelinux中创建不同系统所对应的文件夹

cp /var/ftp/pub/RHEL7_6/images/pxeboot/vmlinuz /var/lib/tftpboot/pxelinux/RHEL7_6

cp /var/ftp/pub/RHEL7_6/images/pxeboot/initrd.img /var/lib/tftpboot/pxelinux/RHEL7_6

cp /var/ftp/pub/RHEL7_6/EFI/BOOT/BOOTX64.EFI /var/lib/tftpboot/pxelinux

cp /var/ftp/pub/RHEL7_6/EFI/BOOT/grubx64.cfg /var/lib/tftpboot/pxelinux

3、创建Legacy模式的安装启动文件default

mkdir /var/lib/tftpboot/pxelinux/pxelinux.cfg

vim default

default 0  #默认进label0

timeout 600  #600秒后自动进label1系统安装

prompt 1

label 0

localboot 0

label 1

kernel RHEL7_6/vmlinuz

append initrd=RHEL7_6/initrd.img inst.repo=ftp://192.168.64.25/pub/RHEL7_6/ ip=dhcp nomodeset ks=ftp://192.168.64.24/pub/RHEL7_6/ks7_6.cfg

4、创建UEFI模式的引导文件grub.efi

vim /var/lib/tftpboot/pxelinux/grub.efi

menuentry 'Install Red Hat Enterprise Linux 7.6' --class fedora --class gnu-linux --class gnu --class os {

linuxefi /pxelinux/RHEL7_6/vmlinuz inst.repo=ftp://192.168.64.25/pub/RHEL7_6  ks=ftp://192.168.64.24/pub/RHEL7_6/ks7_6.cfg

initrdefi /pxelinux/RHEL7_6/initrd.img

}

5、将/var/lib/tftpboot/pxelinux.0文件拷贝到/var/lib/tftpboot/pxelinux文件夹中

五、重启PXE服务器

六、重启PXE服务器系统下的相关服务

service dhcpd restart

service xinetd restart

service vsftpd restart

service tftp restart

基于Linux系统的PXE搭建方法的更多相关文章

  1. 基于Linux系统--web环境搭建

    上线部署文档 数据库部分1.下载Mysql服务    #yum  install  mysql-server 2.更改             /etc/my.cnf 3.启动Mysql        ...

  2. 孤荷凌寒自学python第六十一天在Fedora28版的linux系统上找搭建本地Mongodb数据服务

    孤荷凌寒自学python第六十一天在Fedora28版的linux系统上找搭建本地Mongodb数据服务 (完整学习过程屏幕记录视频地址在文末) 今天是学习mongoDB数据库的第七天.成功在本地搭建 ...

  3. 基于Linux系统的Nagios网络管理模块的实现

    基于Linux 系统的Nagios网络管理模块的实现 1.引言 随着计算机网络的普及,网络管理已成为信息时代中最重要的问题之一.在现有的技术条件下,人们希望有一个更加稳定可靠的网络环境.计算机网络管理 ...

  4. Linux系统中安装软件方法总结

    Linux系统中安装软件方法总结 [1]Linux系统中安装软件的几种方式 [2] Linux配置yum源(本地源和网络源) [3] SuSE下zypper源配置 [4] SUSE zypper 本地 ...

  5. linux系统下本地搭建git服务器

    linux系统下如何搭建本地git服务器,用于存放团队的开发代码,如下步骤: 1.先用一台服务器来安装git,安装好linux以后,在这里选用的是Ubuntu 14.04.然后配置静态IP:172.1 ...

  6. linux系统ecshop拿shell方法

    Title:linux系统ecshop拿shell方法  --2011-06-08 13:23 最近弄一个站,对ECSHOP拿shell不了解,导致走了很多的弯路. nginx/0.8.54的服务器, ...

  7. 在本机使用虚拟机安装一个linux系统,并搭建ftp服务器

    一.Linux基础使用:linux服务器环境搭建(FTP服务器), 在本机使用虚拟机安装一个linux系统,并搭建ftp服务器,要求能使用ftp服务将本机文件到保存linux虚拟机上 资料: VMwa ...

  8. 基于Linux系统geth的安装

    转载地址 https://blog.csdn.net/qq_36124194/article/details/83658580 基于Linux系统geth的安装 安装ethereum sudo apt ...

  9. 总结四条对学习Linux系统有帮助的方法

    网络是一个很神奇的东西,现代人的生活离不开网络,网络已深入人们的工作,生活,娱乐等方方面面.网络之所以无处不在,是因为它提供了诸多的网络服务,所以网络服务是网络的灵魂. 互联网上的各种网络服务是架构在 ...

  10. 基于Linux系统的病毒

    虽然在Linux里传播的病毒不多,但也是存在一些,我从一些安全网站搜集了一些资料. 1.病毒名称: Linux.Slapper.Worm 类别: 蠕虫 病毒资料: 感染系统:Linux 不受影响系统: ...

随机推荐

  1. nginx之日志切割

    方便查看nginx日志, 平常会将nginx日志进行每日切割处理. 这里介绍 平常比较常用的两种方式 1. logrotate 在linux上logrotate是一个日志文件管理工具.用于分割日志文件 ...

  2. require.js 笔记

    1.前言 随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签来导入一个个的js文件这种方式已经不能满足现在互联网开发模式,我们需要团队协作.模块复用.单元测试等等一系列 ...

  3. 【C++】类的继承的深入探讨

    继承是扩展现有类并为基类提供新功能的一种方式. 本文主要探讨一个问题:子类会包含父类所包含的一切吗? 起初,作者认为这个问题的答案是否定的,因为子类无法访问父类的private成员 但是,运行下述一个 ...

  4. LeetCode题集-5 - 最长回文子串之马拉车(二)

    书接上回,我们今天继续来聊聊最长回文子串的马拉车解法. 题目:给你一个字符串 s,找到 s 中最长的回文子串. 01.中心扩展法优化-合并奇偶处理 俗话说没有最好只有更好,看着O(n^2)的时间复杂度 ...

  5. WxPython跨平台开发框架之参数配置管理界面的设计和实现

    我曾经在2014年在随笔<Winform开发框架之参数配置管理功能实现-基于SettingsProvider.net的构建>介绍过基于.NET开发的参数配置管理界面,本篇随笔基于类似的效果 ...

  6. 设置QToolBar的Action图标之间的间隔

    设置QToolBar的Action图标之间的间隔,网上搜索一大堆没用的,原来非常简单. toolBar->layout()->setContentsMargins(10, 10, 10, ...

  7. 中电金信鲸视:以AI视觉技术为复杂行业场景装上“火眼金睛”

    ​ 作为人工智能和计算机视觉的交叉领域,智能视觉通过仿生人类视觉机能,对不同形式的视觉输入进行处理.理解和决策.现今,智能视觉已成为应用广泛.市场覆盖大.形式多样的产业方向,得到了国家政策的大力支持. ...

  8. Redis应用—9.简单应用汇总

    大纲 1.基于Redis实现的简单缓存机制(String数据结构) 2.实现一个最简单的分布式锁(String数据结构) 3.博客网站的文章发布与查看(String数据结构) 4.博客字数统计与文章预 ...

  9. qemu/kvm

    <domain type="kvm"> <name>win7</name> <uuid>e31c1621-b3c3-42ed-be3 ...

  10. kubeadm卸载清空k8s环境

    #!/bin/bash kubeadm reset -f modprobe -r ipip lsmod rm -rf ~/.kube/ rm -rf /etc/kubernetes/ rm -rf / ...