百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

「开学季」Linux 系统自动化部署系统

gudong366 2025-07-08 00:34 11 浏览

linux安装光盘中的相关文件:

[root@Centos8 cdrom]# ls
BaseOS  EFI  images  isolinux  LICENSE  media.repo  Minimal  TRANS.TBL

#isolinux:存放和安装相关的文件
[root@Centos8 isolinux]# ls
boot.cat  boot.msg  grub.conf  initrd.img  isolinux.bin  isolinux.cfg  ldlinux.c32  libcom32.c32  libutil.c32  memtest  splash.png  TRANS.TBL  vesamenu.c32  vmlinuz

boot.cat: 相当于grub的第一阶段,加载MBR中的bootloader到内存

isolinux.bin:光盘引导程序

isolinux.cfg:启动菜单的配置文件(是一个文本文件,用于设置开机的光盘界面)

....c32:提供了启动菜单功能的文件

memtest:内存检测程序

splash.png:光盘启动菜单界面的背景图

vmlinuz:是内核映像文件

initrd.img:ramfs文件,是linux的一个精简系统,里面有文件系统的驱动

内核参数

isolinux/isolinux.cfg中设置相关的内核加载参数,实现不同的安装过程

#不同的启动模式,比如救援模式等,就是采用了不同的内核参数。

#指定内核参数的方法:
法一:在启动菜单界面,选中一项安装方法,按tab键,在后面增加参数

法二:在启动菜单界面,任意选中一项安装方法,按ESC键:boot: linux 参数设置 (linux表示isolinux.cfg中指定的一个标签)

#常见的内核参数:
text:指定文本方式的安装界面
rescue:进入救援模式
ks=path: 指定自动化安装应答文件路径,

#boot.iso:只是用来启动的镜像文件

自动安装的应答文件

应答文件,称为kickstart文件,用于保存安装过程需要指定的选项。

#kickstart文件主要包括三个部分:命令段,程序包段,脚本段
命令段:指明各种安装前配置,如键盘类型等

#命令段中的常见命令:
	keyboard: 设定键盘类型
	lang: 语言类型
	zerombr:清除mbr
	clearpart:清除分区
	part: 创建分区
	rootpw: 指明root的密码
	timezone: 时区
	text: 文本安装界面
	network:指定网络设置
	firewall:设置防火墙设置
	selinux:设置selinux设置
	reboot:安装完自动重启
	user:安装完成后为系统创建新用户
	url: 指明安装源

#程序包段:指明要安装的程序包组或程序包,不安装的程序包等
	%packages
	@^environment group: 指定环境包组,如:@^minimal-environment
	@group_name
	package
	-package
	%end

#脚本段:
	%pre: 安装前脚本
	%post: 安装后脚本

#注意:
CentOS 8,7,6 不同版本的kickstart文件格式不尽相同,不可混用
 %addon, %packages, %onerror, %pre 、 %post 必须以%end结束,否则安装失败

kickstart文件创建

  • 使用图形工具创建(centos7支持)
  • 使用自带的模板生成
可使用创建工具:system-config-kickstart ,注意:此方法 CentOS 8不再支持

依据某模板修改并生成新配置,CentOS安装完后,会自动参考当前系统的安装过程,生成一个kickstart文件 /root/anaconda-ks.cfg

检查ks文件的语法错误:

使用 ksvalidator 工具可以检查kickstart的文件格式是否有语法错误,来自于 pykickstart 包

格式:ksvalidator /PATH/TO/KICKSTART_FILE

DHCP服务的实现

  • DHCP:Dynamic Host Configuration Protocol,动态主机配置协议
  • DHCP使用的是UDP协议,服务端使用67/udp端口,客户端使用68/udp端口
  • DHCP主要实现的是局域网类自动给客户机分配ip地址、网段、dns等内容

DHCP工作过程:

  1. 客户机发送广播报文寻找DHCP服务器(DISCOVER广播报文)
  2. DHCP服务器回应客户机(OFFER报文)
  3. 客户机回应指定的DHCP服务器(REQUEST报文,先到先得的原则)
  4. DHCP和客户机签订协约(ACK报文)

DHCP的实现

注意:实现DHCP服务前,先将网络已有DHCP服务,如:vmware中的DHCP关闭,访止冲突

DHCP服务的实现软件:

  • dhcp(CentOS 7 之前版本) 或 dhcp-server(CentOS 8 中的包名) #功能更强大
  • dnsmasq:小型服务软件,可以提供dhcp和dns功能

DHCP相关文件的组成

dhcp或dhcp-server 包文件组成
[root@Centos8 ~]# rpm -ql dhcp-server
/etc/NetworkManager
/etc/NetworkManager/dispatcher.d
/etc/dhcp
/etc/dhcp/dhcpd.conf #dhcp服务配置文件
/etc/dhcp/dhcpd6.conf
/etc/openldap/schema 
/etc/openldap/schema/dhcp.schema
/etc/sysconfig/dhcpd
...
/usr/share/doc/dhcp-server/dhcpd.conf.example #dhcp服务配置范例文件
/usr/lib/systemd/system/dhcpd.service ##dhcp服务service文件
/usr/lib/systemd/system/dhcpd6.service
/usr/sbin/dhcpd  #dhcp服务主程序
/usr/share/doc/dhcp-server
/var/lib/dhcpd/dhcpd.leases 地址分配记录
...
/var/lib/dhcpd
...
dhcp-client客户端包
...
/usr/sbin/dhclient #客户端程序
/var/lib/dhclient #自动获取的IP信息
...

DHCP服务器配置文件

cp /usr/share/doc/dhcp-server/dhcpd.conf.example /etc/dhcp/dhcpd.conf #拷贝一个范例文件进行更改
#注意:
DHCP服务器本身采用静态IP

必须配置和DHCP网卡的静态IP所在网段的subnet段,否则DHCP服务无法启动(比如自己的ip是10网段,首先就要给10网段配置dhcp)

#全局配置
subnet {
 ...
 }
host {
}

next-server:提供引导文件的服务器IP地址

filename: 指明引导文件名称

范例

subnet 192.168.100.0 netmask 255.255.255.0 {
 range 192.168.100.10  192.168.100.100; #指明分配的ip地址范围
 range 192.168.100.150  192.168.100.200; #每一行需要以分号结束
 option routers 192.168.100.1; #指定网关
 next-server 192.168.1.100; #TFTP服务器地址
 filename "pxelinux.0";     #bootloader启动文件的名称
}
范例:dhcpd.conf
#dhcp的配置文件每一行使用分号结束
[root@centos8 ~]#grep -v "#" /etc/dhcp/dhcpd.conf
option domain-name "magedu.org";
option domain-name-servers 180.76.76.76, 223.6.6.6; #指定使用的dns
default-lease-time 600;  #指定到期的时间
max-lease-time 7200;
log-facility local7;
subnet 10.0.0.0 netmask 255.255.255.0 { #指定给那个网段分配
 range 10.0.0.10  10.0.0.100; #分配的ip地址范围 
 range 10.0.0.110 10.0.0.200;
 option routers 10.0.0.2; #指定网关
 next-server 10.0.0.8; #指定使用的tftp服务器
 filename "pxelinux.0"; } #指定需要再tftp服务器上下载的文件

host testclient { #给特定的客户端分配的ip地址
 hardware ethernet 00:0c:29:33:b4:1a; #客户端的mac地址
 fixed-address 10.0.0.106; #如果是这个客户端就分配这个ip地址
 default-lease-time 86400; #合约时间
 max-lease-time 864000;
 option routers 10.0.0.254; #网关名
 option domain-name-servers 114.114.114.114,8.8.8.8 ; #dns服务器
 option domain-name "test.net"; } #域名自动补齐
#范例: DHCP服务器给指定主机分配固定IP
[root@centos8 ~]#vim /etc/dhcp/dhcpd.conf
subnet 10.0.0.0 netmask 255.255.255.0 {
   range 10.0.0.50 10.0.0.100;
   range 10.0.0.150 10.0.0.200;
   option routers 10.0.0.2;
   next-server 10.0.0.8;
   filename "pxelinux.0"; }

host test {
 hardware ethernet 00:0c:29:cd:90:10;
 fixed-address 10.0.0.123;
}

实现TFTP服务

TFTP:Trivial File Transfer Protocol ,是一种用于传输文件的简单高级协议,是文件传输协议(FTP)的简化版本。

TFTP使用UDP作为传输层协议,TFTP使用69/udp这个端口

安装和使用TFTP

  • tftp:提供小文件的下载
  • tftp:只需要下载启动起来就行了

实现tftp的软件:

  • tftp-server 服务器包
  • tftp 客户端包
#安装tftp服务器包
[root@centos8 ~]#dnf install tftp-server tftp -y

[root@Centos8 ~]# rpm -ql tftp-server
...
/usr/lib/systemd/system/tftp.service #tftp service文件
/usr/lib/systemd/system/tftp.socket
/usr/sbin/in.tftpd #tftp主程序
/usr/share/doc/tftp-server
...
/var/lib/tftpboot ##TFTP服务数据目录 数据都放在这个目录下面
#启动服务
[root@centos8 ~]#systemctl enable --now tftp.service
#tftp客户端下载服务端的指定文件
tom@ubuntu1804:~$ tftp 192.168.26.129
tftp> get aa.txt  #下载服务端/var/lib/tftpboot下的某个文件
tftp> quit #退出tftp
tftp> status #连接状态的查看
Connected to 192.168.26.129.
Mode: netascii Verbose: off Tracing: off
Rexmt-interval: 5 seconds, Max-timeout: 25 seconds

#以下在tftp服务器执行,当用户下载文件后,可以观察到服务器端自动打开in.tftpd主程序

利用 PXE 实现自动化系统部署

PXE:Preboot Excution Environment,预启动执行环境,是由Intel公司研发
目标:实现基于网络自动化安装系统

利用PXE实现自动化安装流程

PXE网卡:ROM中不但集成了MAC,还集成了DHCP和TFTP客户端。

pxelinux.0 就是一个bootloader。 获取pxelinux.cfg文件(grub二阶段 )

在CentOS 8上实现PXE自动化安装CentOS 7,8

  • 配置服务器环境
  • 安装对应的软件包
  • 配置DHCP服务
  • 配置yum私有仓库
  • 准备应答文件
  • 准备菜单文件

安装前准备:

  • 关闭防火墙和SELINUX,DHCP服务器静态IP
  • 网络要求:关闭Vmware软件中的DHCP服务,基于NAT模式

安装相关软件包并启动

dnf -y install dhcp-server tftp-server httpd syslinux-nonlinux(或者syslinux-tftpboot)

syslinux-nonlinux这个软件包里面提供了pxelinux.0,menu.c32等文件。
menu.c32提供了菜单的功能

配置DHCP服务

配置yum的私有仓库

准备kickstart文件

准备PXE启动相关文件

这些相关文件放在tftp的指定目录下面。( /var/lib/tftpboot/)

[root@centos8 ~]#mkdir /var/lib/tftpboot/centos{6,7,8}
#准备CentOS6,7,8各自的内核相关文件

[root@centos8 ~]#cp /var/www/html/centos/7/os/x86_64/isolinux/{vmlinuz,initrd.img} /var/lib/tftpboot/centos7
[root@centos8 ~]#cp /var/www/html/centos/8/os/x86_64/isolinux/{vmlinuz,initrd.img} /var/lib/tftpboot/centos8
[root@centos8 ~]#cp /usr/share/syslinux/{pxelinux.0,menu.c32} /var/lib/tftpboot/ 

#以下三个文件是CentOS8安装所必须文件,CentOS7不需要

[root@centos8 ~]#cp /var/www/html/centos/8/os/x86_64/isolinux/{ldlinux.c32,libcom32.c32,libutil.c32} /var/lib/tftpboot/
#生成安装菜单文件
[root@centos8 ~]#mkdir /var/lib/tftpboot/pxelinux.cfg/
[root@centos8 ~]#cp /var/www/html/centos/8/os/x86_64/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default

准备启动菜单文件

手动编写一个启动菜单文件

[root@centos8 ~]#vim /var/lib/tftpboot/pxelinux.cfg/default 

default menu.c32 #指定默认使用的界面菜单文件 指定菜单的风格
timeout 600 #超时时间60是、
menu title Install CentOS Linux  #标题
label linux8  #指定标签
 menu label Auto Install CentOS Linux ^8 #指定标题 加了脱字符会高亮
 kernel centos8/vmlinuz #指定使用的内核文件
 append initrd=centos8/initrd.img ks=http://10.0.0.100/ks/centos8.cfg #指定应答文件的位置

label linux7
 menu label Auto Install CentOS Linux ^7
 kernel centos7/vmlinuz
 append initrd=centos7/initrd.img ks=http://10.0.0.100/ks/centos7.cfg


label manual
 menu label ^Manual Install CentOS Linux 8.0
 kernel centos8/vmlinuz
 append initrd=centos8/initrd.img #手动安装
inst.repo=http://10.0.0.100/centos/8/os/x86_64/ #指定repo地址

label rescue #救援模式
 menu label ^Rescue a CentOS Linux system 8
 kernel centos8/vmlinuz
 append initrd=centos8/initrd.img
inst.repo=http://10.0.0.100/centos/8/os/x86_64/ rescue

label local
 menu default   #默认没有任何选择就采用本地硬盘启动
 menu label Boot from ^local drive
 localboot 0xffff

利用cobbler实现自动化安装

CentOS8没有提供这个工具。

相关推荐

U盘文件被删怎么简单恢复(u盘里的文件被误删了怎么找回)

现在这个社会不是靠关系靠路子,主要还是靠实力。刘强在机关工作,人长得帅气,工作能力又强。唯独一样不好,脾气太大,动不动就发火,因为小事常和同事发生口角。一次他火大的差点把办公桌给掀翻了,领导见他野蛮的...

不小心删除了一些文件?9 个最佳免费硬盘恢复软件

恢复您曾经无意或意外删除的所有文件和数据。您是否曾经错误地删除了一个对您的工作至关重要并导致您丢失所有进度的文件?我们为您提供了一些最好的免费硬盘恢复软件,以帮助您恢复意外删除的文件,以解决您的文件删...

Studio 中文版:数据救援神器,误删 / 分区损坏 / RAID 恢复一键找回

Studio中文版:数据救援神器,误删/分区损坏/RAID恢复一键找回当文件意外删除、分区损坏,或RAID阵列崩溃时,一款可靠的数据恢复工具往往能挽回关键损失。R-Studio中文版...

你值得拥有的11款Linux数据恢复工具

如果你使用的是Linux操作系统,那么你一定想知道一旦硬盘崩溃的话又该如何保存和恢复数据。其实,现在有很多Linux数据恢复工具可以让我们摆脱数据安全的困扰。小编已经为各位准备好了一些最好的Linux...

误删文件内容怎么恢复(误删文件内容怎么恢复回来)

  在日常使用电脑的过程中,误删文件的情况时有发生。无论是由于操作失误还是病毒攻击,误删文件都会给我们带来不小的困扰。幸运的是,随着技术的发展,误删文件恢复已不再是难题。本文将介绍几款国内外知名的误删...

u盘如何恢复删除的文件?推荐5款u盘数据恢复软件!

在日常生活与工作中,U盘作为便捷的数据存储载体,频繁用于传输和保存各类重要文件。然而,误删文件的情况却时有发生,无论是珍贵的照片、重要的工作文档,还是精心制作的视频,一旦删除,都可能带来不小的麻烦。...

怎么恢复删除的数据?5种有效的数据恢复方法汇总!

在数字化办公与生活的时代,电脑里的每一份数据都承载着重要信息。然而,一个误操作就可能导致数据被删除,无论是尚未保存的重要文档,还是珍藏多年的照片,都可能瞬间“消失”。但其实,数据删除并不意味着永久丢...

u盘删除文件怎么找回?5个数据恢复工具汇总,助你巧妙恢复数据!

在日常使用U盘的过程中,误删文件的情况时有发生,重要的工作文档、珍贵的照片视频一旦消失,难免让人焦急万分。别担心,只要选对数据恢复工具,被删除的数据仍有找回的可能。下面就为你汇总5款实用的数据...

Linux下恢复误删文件:思路+实践(linux删除如何恢复)

周五篮球群里有人问误删文件了怎么恢复,得知是ext4文件系统之后我推荐了ext4magic这个工具,然后又有人提到了xfs的话怎么办,正好前几天看到DaveChinner在邮件列表里提到了这个问题,...

苹果放大招!不用虚拟机了,Mac直接跑Linux容器,开发者效率翻倍

苹果这次真给开发者送福利了!今天凌晨(6月10日),苹果在官宣的Containerization框架直接炸了技术圈——Mac现在能原生运行Linux容器镜像了!这可不是虚拟机那种“套娃”方案,而是基...

7 款老牌经典软件,值得收藏(经典老歌软件)

Calibrehttps://calibre-ebook.com/Calibre是一个电脑电子书管理软件。肯定有人说了,电子书还要管理?那当然了。它的功能更强大的让你想象不到,首先它可以导入PDF,...

神仙级的免费开源电子书阅读器,还支持听书功能

神仙级的免费开源电子书阅读器,还支持听书功能,极空间部署『KoodoReader』哈喽小伙伴们好,我是Stark-C~前段时间不是给大家分享的电子书管理工具『TaleBook』嘛~,然后就有粉丝私信...

如何在Ubuntu系统中重置root密码(ubuntu忘记密码重置root密码命令)

很多人有个问题,就是喜欢把密码设置得很长很复杂,结果谁也没防住,却成功防住了自己ヽ(.ˇдˇ;)ノ对于现代人,特别是年轻人,都有过忘记密码的经历吧。在这篇文章中,我们来了解如何在Ubuntu1...

5款功能强大的PDF阅读器,让PDF阅读更轻松

分享5款功能强大的PDF阅读器,拥有丰富的PDF阅读工具,支持PDF文档划线、笔记、标记等操作,让PDF阅读更轻松!1.嗨动PDF编辑器一款实用的PDF处理软件,不仅可以阅读PDF文档,还能直接编辑、...

上班摸鱼利器! 免费好用的电子书阅读器,NAS轻松部署Koodo Reader

哈喽,大家好我是生活爱好者。笔者也是一名小说爱好者,平时用手机用某信读书,会员也开了,在家看体验也不错,但是上班的时候,在工作快速完成之后,想摸个鱼用手机就不太方便啦,作为爱折腾的人,必须要工作认真,...