IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Linux——PXE高效批量网络装机 -> 正文阅读

[系统运维]Linux——PXE高效批量网络装机


前言

大规模的 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.110;		#配置网关
  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 软件提供。
  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-09-07 11:12:00  更:2021-09-07 11:12:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/12 4:49:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码