PXE-kickstart无人值守批量装机

眉间皱痕 提交于 2019-12-02 05:15:15

PXE-kickstart无人值守安装

服务器的批量部署:

  • 规模化:同时装配多台服务器

  • 自动化:安装系统、配置各种服务

  • 远程实现:不需要光盘、U盘等安装介质

PXEPre-boot eXcution Environment

  • 预启动执行环境,在操作系统之前运行

  • 可用于远程安装、构建无盘工作站

服务端

  • 运行DHCP服务,用来分配地址、定位引导程序

  • 运行TFTP服务器,提供引导程序下载

客户端

  • 网卡支持PXE协议

  • 主板支持网络启动

搭建PXE远程安装服务器:

1. 准备RHEL 6.1安装源(YUM仓库)

rhel 6的网络安装源一般通过HTTPFTP协议发布,也支持NFS(网络文件系统)协议:

eg:本例采用FTP协议发布安装源,在服务器上部署YUM软件仓库:

153343839.png

2. 启用TFTP服务,并提供内核、引导程序:

TFTP服务由tftp-server软件包提供,默认由xinetd超级服务进行管理,配置文件位置:/etc/xinetd.d/tftp,将“disable = yes”改为“disable = no”,然后启动xinetd服务。

153343270.png

153344620.png

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

rhel6系统光盘images/pxeboot中复制用于PXE网络安装的Linux内核(vmlinuz)、初始化镜像文件(initrd.img)。

[root@PXE ~]# cd /media/images/pxeboot/

[root@PXE pxeboot]# cp vmlinuz initrd.img /var/lib/tftpboot/

153344834.png

4. 准备PXE引导程序、启动菜单文件:

用于PXE网络安装的引导程序为pxelinux.0,由软件包syslinux提供,安装此软件并将文件pxelinux.0复制到tftp服务的根目录下:

[root@PXE ~]# yum -y install syslinux

[root@PXE ~]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/

153344749.png

[root@PXE ~]# mkdir /var/lib/tftpboot/pxelinux.cfg

[root@PXE ~]# cp /media/isolinux/isolinux.cfg/var/lib/tftpboot/pxelinux.cfg/default

[root@PXE ~]# chmod 644 /var/lib/tftpboot/pxelinux.cfg/default

153344540.png

153344236.png

(这里测试环境不一样,如果要验证非自动装机,就不用写 ks 这一项,实际位置为ks=ftp://192.168.10.1/rhel6/ks.cfg

5. 安装并启用DHCP服务:

使用PXE部署安装所使用的客户机通常都是未安装系统的裸机,所以为了与服务器取得联系并正确下载相关引导文件,需要配置DHCP服务来自动分配地址并告知引导文件位置:

153344585.png

subnet192.168.10.0netmask 255.255.255.0 {

    optionrouters 192.168.10.1;

    default-lease-time21600;

    max-lease-time43200;

    range 192.168.10.100 192.168.10.200;

    optionsubnet-mask 255.255.255.0;

    next-server 192.168.10.1;

    filename "pxelinux.0";

}

153402963.png

注意:防火墙规则必须清除 或者建立相应的规则。

153402787.png

现在前期环境就搭建好了,可以在客户机进行安装测试。

缺点:安装需要人为手动选择,在生产环境下并不适应。

实现Kickstart无人值守安装:

准备安装应答文件:system-config-kickstart,需要安装。

153402117.png

配置安装应答参数:

打开kickstart配置程序:

153402882.png

或者通过命令行直接打开:

153402199.png

基本信息及安装方法(语言、时区、根口令,并勾选“安装后重新引导系统”):

153403992.png

指定正确的rhel 6安装源:

153403904.png

153403499.png

选择正确的分区规划方案:

153431500.png

网络配置及防火墙配置(在网络配置中添加"eth0"网络设备,将网络类型设置为DHCP;):

153431977.png

153431993.png

153431579.png

153432488.png

软件包安装选择(桌面及开发勾选相应选项):

153432883.png

153432969.png

安装后的执行脚本(用来做验证):

153432539.png

153556853.png

保存应答文件并查看信息:

153556836.png

153556307.png

实现Linux批量自动装机:

启动自动应答文件:

ks.cfg的启动应答文件复制到/var/ftp/rhel6/目录下,使客户机能通过ftp://192.168.10.1/rhel6/ks.cfg访问。然后编辑引导菜单文件default,添加ks引导参数以指定ks.cfg应答文件的URL路径:

153556995.png

注意:无系统时不建议调启动项,不然安装完成后会一直重复循环安装。

153556253.png

为了防止批量部署失败,关闭虚拟机自带DHCP功能。

153556884.png

开始批量部署:提示IP地址获取成功,开始安装部署。

153557548.png

153557887.png

安装完成后验证之前设置的安装后创建yum脚本,验证成功:

153557511.png

归结:

kickstart无人值守技术的优点:

  • 创建应答文件,预先定义好各种安装设置

  • 免去交互设置过程,从而实现全自动化安装

  • 通过添加%post脚本,完成安装后的各种配置操作

整个部署过程到此结束,简单、方便、快捷才是王道。

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!