Linux——PXE高效批量网络装机

2023-05-16

文章目录

  • 前言
  • 一、部署PXE远程安装服务
    • 1.批量部署的前提条件
    • 2.PXE批量部署的优点
    • 3.PXE启动方式
    • 4. 基本部署过程
    • 5.PXE服务器和客户机的工作过程:
    • 6.搭建 PXE 远程安装服务器
      • 6.1 添加网卡并配置网卡信息
      • 6.2 安装并启用 DHCP 服务
      • 6.3 安装并启用 TFTP 服务
      • 6.4 准备 Linux 内核、初始化镜像文件
      • 6.5 准备 PXE 引导程序
      • 6.6 安装 FTP 服务,准备 CentOS 7 安装源
      • 6.7 配置启动菜单文件
      • 6.8 验证 PXE 网络安装
  • 二、实现Kickstar无人值守安装
    • 1. Kickstart 概述
    • 2.准备安装应答文件
      • 2.1 打开配置程序窗口
      • 2.2 基本配置
      • 2.3 指定保存的目录位置
      • 2.4 自动配置安装包
  • 总结


前言

大规模的 Linux 应用环境中,服务器往往并不配备光驱设备,在这样的情况下,如何为数十乃至上百台服务器裸机快速安装系统呢?下面我来介绍一下,通过 PXE 技术远程安装系统,并且实现无人值守安装的操作。

一、部署PXE远程安装服务

PXE是由 Intel 公司开发的网络引导技术,工作在 Client/Server 模式,允许客户机通过网络从远程服务器下载引导镜像,并加载安装文件或者整个操作系统。

1.批量部署的前提条件

  • 客户机的网卡支持 PXE协议(集成BOOTROM芯片),且主板支持网络引导。
  • 网络中有一台 DHCP服务器以便为客户机自动分配地址、指定引导文件位置。
  • 服务器通过 TFTP (Trivial File Transfer Protocol,简单文件传输协议)提供引导镜像文件的下载。
    其中,第一个条件实际上是硬件要求,目前绝大多数服务器和大多数 PC 都能够提供此支持,只需在BIOS 设置中允许从 Network 或 LAN 启动即可。

2.PXE批量部署的优点

  • 规模化:同时装配多台服务器
  • 自动化:安装系统、配置各种服务
  • 远程实现:不需要光盘、U盘等安装介质
    在这里插入图片描述

3.PXE启动方式

  • PXE (Preboot eXcution Environment)
    预启动执行环境,在操作系统之前运行
  • 服务端
    运行DHCP服务,用来分配地址、定位引|导程序
    运行TFTP服务,提供引导程序下载
  • 客户端
    网卡支持PXE协议
    主板支持网络引导

4. 基本部署过程

1.准备CentOS 7安装源(YUM仓库)
2.安装并启用TFTP服务
3.提供Linux内核、PXE引导程序等
4.安装并启用DHCP服务
5.配置启动菜单

5.PXE服务器和客户机的工作过程:

  1. PXE客户机发出DHCP请求,向DHCP服 务器申请IP地址:。
  2. DHCP服务器响应PXE客户机的请求,自动从IP地址池中分配- - 个IP地址给PXE客户机,并且告知PXE客户机: TFTP服 务器的IP地址和PXE引导程序文件pxelinux.0,默认在TFTP共享目录/var/1ib/tftpboot/下
  3. PXE客户机向TFTP服务器发起获取pxelinux.0引导程序文件的请求。
  4. TFTP服务器响应PXE客户机的请求,将其共享的pxelinux.0文件传输给PXE客户机。
  5. PXE客户机通过网络米启动到系统安装主界而。
  6. PXE客户机向文件共享服务器(ftp、 http、 nfs等)发起获取centos或windows系统安装文件的请求。
  7. 文件共享服务响应PXE客户机的请求,将共享的系统安装文件传输给PXE客户机。
  8. PXE客户机进入到安装提示向导界而,用户需要手动来完成系统安装的操作

6.搭建 PXE 远程安装服务器

6.1 添加网卡并配置网卡信息

在这里插入图片描述

[root@localhost ~]#cd /etc/sysconfig/network-scripts/
[root@localhost /etc/sysconfig/network-scripts]#cp ifcfg-ens33 ifcfg-ens37
[root@localhost /etc/sysconfig/network-scripts]#vim ifcfg-ens37
TYPE=Ethernet
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=static
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy
NAME=ens37
DEVICE=ens37
ONBOOT=yes
IPADDR=192.168.152.110
NETMASK=255.255.255.0
GATEWAY=192.168.152.1
#DNS1=144.144.144.144
#DNS2=8.8.8.8
[root@localhost /etc/sysconfig/network-scripts]#systemctl restart network

6.2 安装并启用 DHCP 服务

yum install -y dhcp
cp -rfp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf
vim /etc/dhcp/dhcpd.conf
……
subnet 192.168.152.0 netmask 255.255.255.0 {		#配置网段
  range 192.168.152.40 192.168.152.50;		#配置地址池
  option routers 192.168.152.1;		#配置网关
  next-server 192.168.152.110;		#指定tftp服务器地址
  filename "pxelinux.0";		#指定PXE引导程序的文件名
……
#重启DHCP服务并设置开机自启
systemctl restart dhcpd
systemctl enable dhcpd

6.3 安装并启用 TFTP 服务

yum install tftp-server.x86_64 -y
vim /etc/xinetd.d/tftp
service tftp
{
        socket_type             = dgram
        protocol                = udp
        wait                    = no	//no表示客户机可以多台一起连接,yes表示客户机只能一一台一- 台连接,表示是否开启多线程一起工作,否则需要等待
        user                    = root
        server                  = /usr/sbin/in.tftpd
        server_args             = -s /var/lib/tftpboot	//指定TFTP根目录,-c允许上传
        disable                 = no(yes改为no)	//no表示开启TFTP服务
        per_source              = 11	//限制主机最大连接数,防止某个主机独占服务
        cps                     = 100 2		//表示服务器最多启动100个连接,达到会停2s
        flags                   = IPv4
}

#重启TFTP服务并设置开机自启
systemctl restart tftp
systemctl enable tftp

6.4 准备 Linux 内核、初始化镜像文件

mount /dev/sr0 /mnt/

复制Linux系统内核文件和初始化镜像文件

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

6.5 准备 PXE 引导程序

yum install -y syslinux
rpm -ql syslinux |grep pxelinux		//查看一下pxelinux.0在哪个目录下
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot		//#拷贝到tftp的根目录下。系统引导文件

6.6 安装 FTP 服务,准备 CentOS 7 安装源

yum install -y vsftpd
mkdir /var/ftp/centos7
cp -rf /mnt/* /var/ftp/centos7/

启动服务并设置开机自启

systemctl start vsftpd
systemctl enable vsftpd

6.7 配置启动菜单文件

cd /var/lib/tftpboot
mkdir pxelinux.cfg
vim pxelinux.cfg/default
default auto
prompt 0

label auto
        kernel vmlinuz
        append initrd=initrd.img method=ftp://192.168.152.110/centos7   ks=ftp://192.168.152.110/ks.cfg

label linux text
        kernel vmlinuz
        append text initrd=initrd.img method=ftp://192.168.152.110/centos7      ks=ftp://192.168.152.110/ks.cfg


label linux rescue
        kernel vmlinuz
        append rescue initrd=initrd.img method=ftp://192.168.152.110/centos7    ks=ftp://192.168.152.110/ks.cfg

6.8 验证 PXE 网络安装

直接启动
在这里插入图片描述
在这里插入图片描述

二、实现Kickstar无人值守安装

1. Kickstart 概述

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

2.准备安装应答文件

2.1 打开配置程序窗口

在这里插入图片描述

2.2 基本配置

包括语言、时区、系统安装方法、分区信息、网络配置、防火墙设置
在这里插入图片描述

2.3 指定保存的目录位置

在这里插入图片描述

2.4 自动配置安装包

将anaconda-ks.cfg所有的软件包拷贝到 /var/ftp/ks,cfg

cd /root
vim anaconda-ks.cfg
……
%packages
@^gnome-desktop-environment
@base
@core
@desktop-debugging
@development
@dial-up
@directory-client
@fonts
@gnome-desktop
@guest-agents
@guest-desktop-agents
@input-methods
@internet-browser
@java-platform
@multimedia
@network-file-system-client
@networkmanager-submodules
@print-client
@x11
chrony
kexec-tools

%end
vim /var/ftp/ks.cfg		//粘贴至行尾,保存退出
%packages
@^gnome-desktop-environment
@base
@core
@desktop-debugging
@development
@dial-up
@directory-client
@fonts
@gnome-desktop
@guest-agents
@guest-desktop-agents
@input-methods
@internet-browser
@java-platform
@multimedia
@network-file-system-client
@networkmanager-submodules
@print-client
@x11
chrony
kexec-tools

%end

重新启动,等待自动安装。

总结

  • 实现 PXE 远程装机要求网卡支持,且必须有 Linux 安装源,以及可用的 TFTP、DHCP 服务器。
  • 无人值守的应答文件可通过 Kickstart 配置程序来完成,该程序由 system-config-kickstart 软件提供。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Linux——PXE高效批量网络装机 的相关文章

  • 通过 SSH 将变量传递给远程脚本

    我正在通过 SSH 从本地服务器在远程服务器上运行脚本 首先使用 SCP 复制该脚本 然后在传递一些参数时调用该脚本 如下所示 scp path to script server example org another path ssh s
  • 如何在 Linux 中使用单行命令获取 Java 版本

    我想通过单个命令获取 Linux 中的 Java 版本 我是 awk 的新手 所以我正在尝试类似的事情 java version awk print 3 但这不会返回版本 我将如何获取1 6 0 21从下面的Java版本输出 java ve
  • 如何使用ffmpeg重叠和合并多个音频文件?

    我正在尝试将多个音频文件合并到一个文件中 但我可以使用以下命令来连接 而不是连接 ffmpeg v debug i file1 wav i file2 wav i file3 wav filter complex 0 0 concat n
  • 如何仅将整个嵌套目录中的头文件复制到另一个目录,在复制到新文件夹后保持相同的层次结构

    我有一个目录 其中有很多头文件 h 和其他 o 和 c 文件以及其他文件 这个目录里面有很多嵌套的目录 我只想将头文件复制到一个单独的目录 并在新目录中保留相同的结构 cp rf oldDirectory newDirectory将复制所有
  • 如何在 Linux x86_64 上模拟 iret

    我正在编写一个基于 Intel VT 的调试器 由于当 NMI Exiting 1 时 iret 指令在 vmx guest 中的性能发生了变化 所以我应该自己处理vmx主机中的NMI 否则 guest会出现nmi可重入错误 我查了英特尔手
  • Windows 与 Linux 文本文件读取

    问题是 我最近从 Windows 切换到 Ubuntu 我的一些用于分析数据文件的 python 脚本给了我错误 我不确定如何正确解决 我当前仪器的数据文件输出如下 Header 有关仪器等的各种信息 Data 状态 代码 温度 字段等 0
  • 我应该使用哪个 Linux 发行版作为 Xen 主机? [关闭]

    Closed 这个问题是基于意见的 help closed questions 目前不接受答案 我为家庭办公室订购了一台服务器 我想用 Xen 对其进行分区 我认为这将使事情保持干净并且更容易维护 我将运行 MySQL PostgreSQL
  • 是否从页面缓存中的脏页面进行文件读取?

    当字节写入文件时 内核不会立即将这些字节写入磁盘 而是将这些字节存储在页缓存中的脏页中 回写缓存 问题是 如果在脏页刷新到磁盘之前发出文件读取 则将从缓存中的脏页提供字节 还是首先将脏页刷新到磁盘 然后进行磁盘读取以提供字节 将它们存储在进
  • 为 Linux 安装 R 包时出错

    我试图在 R 3 3 上安装一个名为 rgeos 的包 但是当我输入 install packages rgeos 但它返回给我以下错误 其他包也会发生同样的情况 但不是所有包 gt installing source package rg
  • 如何从linux命令行运行.exe可执行文件? [关闭]

    Closed 这个问题不符合堆栈溢出指南 help closed questions 目前不接受答案 我在 Windows 中有一个 abc exe 可执行文件 我可以使用 DOS 命令提示来执行此应用程序 并为其提供一些运行时变量 我想从
  • 如何查明 Ubuntu 上安装了哪个版本的 GTK+?

    我需要确定 Ubuntu 上安装了哪个版本的 GTK 男人似乎不帮忙 这个建议 https stackoverflow com a 126145 会告诉您安装了哪个 2 0 的次要版本 不同的主要版本将具有不同的包名称 因为它们可以在系统上
  • 将数组传递给函数名称冲突

    Specs GNU bash 版本 3 1 17 无法升级 Premise 我一直在摆弄数组 我想知道是否有任何方法可以让函数的本地变量与所述函数外部的数组同名 Example 在下面的示例中 我将尝试显示该问题 Working bin b
  • 怎样才能使 Windows 成为一个开箱即用的 POSIX 兼容操作系统?

    这个问题的动机是我的一个牵强的梦想 即 nix 平台上可用的许多优秀软件可以轻松移植到 Windows 微软最近对开源和开放性采取了不同的方法 所以我真的很想知道如果微软有这样的倾向 这样的事情会有多可行 我很好奇的一些更具体的事情是 是否
  • 构建 makefile 依赖/继承树

    如果我解释得不好或者问了一些明显的问题 我很抱歉 但我是 Linux 内核的新手 而且有点深入 我们有一个嵌入式 Linux 系统 它附带一个 文档非常糟糕的 SDK 其中包含数百个文件夹stuff 大多数文件夹包含rules make m
  • 停止服务时单元陷入故障状态(状态=143)[关闭]

    Closed 这个问题不符合堆栈溢出指南 help closed questions 目前不接受答案 这是我的问题 我有 CentOS 和 java 进程在上面运行 Java进程是通过启动 停止脚本来操作的 它也创建了 java 实例的 p
  • 在 LINUX 上使用 Python 连接到 OLAP 多维数据集

    我知道如何在 Windows 上使用 Python 连接到 MS OLAP 多维数据集 嗯 至少有一种方法 通常我使用 win32py 包并调用 COM 对象进行连接 import win32com client connection wi
  • 标准头文件中的 C 编译器错误 - 未定义的 C++ 定义

    我正在尝试编译 C 程序 但收到许多错误 这些错误是在标准 C 头文件 inttypes h stdio h stat h 等 中遇到的 错误的来源是以下未定义的常量 BEGIN DECLS END DECLS BEGIN NAMESPAC
  • 在 Ubuntu 16.04 上找不到 printf.c

    我最近切换到Ubuntu 16 04 我在用vscode作为 Ubuntu 上的 IDE 我配置了其他语言 但我无法做到这一点C C 我创建c cpp properties json launch json tasks json 当我开始编
  • linux x86 汇编语言 sys_read 调用的第一个参数应为 0 (stdin)

    我正在编写一个简单的汇编程序来从标准输入读取 如 scanf 这是我的代码 section bss num resb 5 section txt global start start mov eax 3 sys read mov ebx 0
  • 劫持系统调用

    我正在编写一个内核模块 我需要劫持 包装一些系统调用 我正在暴力破解 sys call table 地址 并使用 cr0 来禁用 启用页面保护 到目前为止一切顺利 一旦完成 我将公开整个代码 因此如果有人愿意 我可以更新这个问题 无论如何

随机推荐