PXE高效批量网络装机

一,部署PXE远程安装服务

1:搭建PXE远程安装服务器

1.准备CentOS7安装源

  • 下载ISO : 访问CentOS官方网站(https://www.centos.org/),下载CentOS 7的ISO镜像文件。

  • 挂载ISO : 假设ISO文件位于/root/CentOS-7-x86_64-DVD.iso,可以使用以下命令挂载:

    mkdir /mnt/centos
    mount -o loop /root/CentOS-7-x86_64-DVD.iso /mnt/centos
    
  • 复制安装源 : 将必要的安装文件复制到TFTP服务器的指定目录,例如/var/lib/tftpboot/centos7:

    cp -r /mnt/centos/Packages /var/lib/tftpboot/centos7
    cp -r /mnt/centos/images/pxeboot/* /var/lib/tftpboot/centos7/pxeboot/
    

2.安装并启用TFTP服务

  • 安装软件: 使用以下命令安装TFTP服务和xinetd:

    yum install tftp-server xinetd -y
    
  • 编辑TFTP配置 : 打开/etc/xinetd.d/tftp,确保配置如下:

    service tftp
    {
        socket_type     = dgram
        protocol        = udp
        wait            = yes
        user            = root
        server          = /usr/sbin/in.tftpd
        server_args     = -s /var/lib/tftpboot
        disable         = no
        per_source      = 11
        cps             = 100 2
        flags           = IPv4
    }
    
  • 启动服务:

    systemctl start xinetd
    systemctl enable xinetd
    systemctl start tftp
    systemctl enable tftp
    

3.准备Linux内核,初始化镜像文件

  • 直接从第1.1步复制的pxeboot目录中已有vmlinuzinitrd.img,无需额外操作。

4.准备PXE引导程序

  • 安装syslinux:

    yum install syslinux -y
    
  • 复制引导文件:

    cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
    

5.安装并启用DHCP服务

  • 安装DHCP:

    yum install dhcp -y
    
  • 编辑DHCP配置 : 编辑/etc/dhcp/dhcpd.conf,添加如下内容(记得替换<your_tftp_server_ip>为你的TFTP服务器IP地址):

    subnet <your_subnet> netmask <your_netmask> {
        range <dhcp_start_ip> <dhcp_end_ip>;
        option routers <your_router_ip>;
        option domain-name-servers <dns_server_ip>;
        
        # PXE Settings
        next-server <your_tftp_server_ip>;
        filename "pxelinux.0";
    }
    
  • 启动DHCP服务:

    systemctl start dhcpd
    systemctl enable dhcpd
    

6.配置启动菜单文件

  • 创建菜单文件 : 在/var/lib/tftpboot/pxelinux.cfg目录下创建default文件,内容如下:

    default centos7
    prompt 0
    timeout 60
    
    label centos7
        kernel centos7/pxeboot/vmlinuz
        append initrd=centos7/pxeboot/initrd.img inst.stage2=http://<your_http_server_ip>/centos7 images/pxeboot/ks.cfg
    

其中,http://<your_http_server_ip>/centos7应指向包含CentOS安装包的HTTP服务器目录,ks.cfg是Kickstart文件,用于自动化安装过程。

2:验证PXE网络安装

  • 客户端设置: 确保客户端计算机的BIOS或UEFI设置中,网络启动(PXE Boot)被设置为优先启动项。
  • 测试安装: 重新启动客户端计算机,它应该会自动从网络启动并显示安装菜单。按照菜单提示进行,即可开始安装过程。

以上步骤完成后,你就可以通过PXE网络安装CentOS 7了。注意,实际操作时可能需要根据具体的网络环境和需求进行适当调整。

二,实现Kickstart无人值守安装

1:准备安装应答文件

在 CentOS7系统中安装 system-config-kickstart 工具之后,即可通过图形化向导工具来配置安装应答文件。如果用户对自动应答文件的配置比较熟悉,也可以直接编辑 CentOS7 安装后自动创建的应答文件(rootanaconda-ks.cfg),根据需要适当修订后使用。

1.配置安装应答参数

  • 编写Kickstart文件: Kickstart文件是一个文本文件,包含了安装过程中需要的所有交互式输入信息。以下是基本结构示例,你可以根据实际需求进行修改:

    #version=DEVEL
    install
    url --url=http://<your_http_server_ip>/centos7
    lang en_US.UTF-8
    keyboard us
    timezone America/New_York
    rootpw --iscrypted <encrypted_password>
    network --bootproto dhcp --device eth0
    firewall --disabled
    selinux --disabled
    reboot
    text
    autopart
    bootloader --location=mbr
    %packages
    @base
    %end
    %post
    # Custom post-installation scripting here, if needed
    %end
    
  • install: 表明这是一个安装任务。

  • url: 指定安装源的URL。

  • lang, keyboard, timezone: 分别设定语言、键盘布局和时区。

  • rootpw: 设置root用户的密码,--iscrypted表示密码已经加密。

  • network: 配置网络设置,这里假设使用DHCP。

  • firewall, selinux: 关闭防火墙和SELinux。

  • autopart: 自动分区。

  • %packages: 指定要安装的软件包组或单个包。

  • %post: 定义安装后执行的脚本。

2.保存自动答应文件

  • 将上述内容保存为一个文本文件,通常命名为ks.cfg,并上传到HTTP服务器的某个目录下(例如之前提到的/centos7目录)。

2:实现批量自动装机

1.启用自动答应文件

  • 在PXE菜单配置文件(如/var/lib/tftpboot/pxelinux.cfg/default)中,确保Kickstart文件的引用路径正确无误。在之前的示例中,我们已经通过以下参数指定了Kickstart文件的路径:

    append initrd=... inst.stage2=http://<your_http_server_ip>/centos7 images/pxeboot/ks.cfg
    

这里inst.stage2后面跟的是Kickstart文件的HTTP地址。

2.验证无人值守安装

  • 客户端验证: 确认客户端的BIOS设置为PXE优先启动后,重新启动客户端。系统应自动从网络启动,遵循Kickstart文件中的配置进行无人干预安装。
  • 监控日志: 在安装服务器上,可以通过系统日志(如/var/log/messages或/var/log/dhcpd.log)来监控PXE启动和安装过程中的错误信息。
  • 验证安装结果: 安装完成后,客户端应当自动重启并进入已安装好的CentOS 7系统,无需任何人工干预。登录系统检查是否所有预期的软件包、配置都已正确应用。
相关推荐
sone121387 分钟前
计算机网络(第8版)第四章 网络层(4.7.1~4.7.3)
服务器·网络·计算机网络
DO_Community19 分钟前
DigitalOcean Droplet 云服务器:新增自动扩展池功能
服务器
安科瑞刘鸿鹏24 分钟前
老旧小区用电安全保护装置#限流式防火保护器参数介绍#
运维·服务器·物联网·能源
ladymorgana32 分钟前
【运维笔记】windows 11 中提示:无法成功完成操作,因为文件包含病毒或潜在的垃圾软件。
运维·windows·笔记
Rain_Rong43 分钟前
linux检测硬盘
linux·运维·服务器
我曾经是个程序员1 小时前
鸿蒙学习记录之http网络请求
服务器·学习·http
0zxm1 小时前
06 - Django 视图view
网络·后端·python·django
李昊哲小课1 小时前
deepin 安装 zookeeper
大数据·运维·zookeeper·debian·hbase
真真-真真2 小时前
WebXR
linux·运维·服务器
轩辰~2 小时前
网络协议入门
linux·服务器·开发语言·网络·arm开发·c++·网络协议