kickstart模式实现批量安装centos7.x系统
1.1 安装系统的方法
l 光盘(ISO文件,光盘的镜像文件)===»每一台物理机都得给一个光驱,如果用外置光驱的话,是不是每台机器都需要插一下
l U盘:ISO镜像刻录到U盘==»需要每台机器都需要插一下
l 并行安装==»网络安装
l 自动化安装
1.2 linux下批量安装系统
kickstart是RedHat公司开源的软件,所以对CentOS兼容性最好。
原理:
我们将手动安装的所有的详细步骤记录到一个文件中,然后kickstart通过读取这个文件就可以实现自动化安装系统。
kickstart是一个项目的名称。没有这个软件。使用者水平是高中以上
cobbler是对kickstart的所有组件的封装。使用者水平是初中以上。本质上就是网页版本的kickstart。
1.2.1 PXE说明
PXE,全名Pre-boot Execution Environment,预启动执行环境;
通过网络接口启动计算机,不依赖本地存储设备(如硬盘)或本地已安装的操作系统;
由Intel和Systemsoft公司于1999年9月20日公布的技术;
客户端/Server的工作模式;
PXE客户端会调用网际协议(IP)、用户数据报协议(UDP)、动态主机设定协议(DHCP)、小型文件传输协议(TFTP)等网络协议;
PXE客户端(客户端)这个术语是指机器在PXE启动过程中的角色。一个PXE客户端可以是一台服务器、笔记本电脑或者其他装有PXE启动代码的机器(我们电脑的网卡)
1.2.2 kickstart原理
1.2.3 PXE请求顺序说明
① PXE 客户端发送UDP广播请求
PXE 客户端从自己的PXE网卡启动,通过PXE BootROM(自启动芯片)会以UDP(简单用户数据报协议)发送一个广播请求,向本网络中的DHCP服务器索取IP。
② DHCP****服务器提供信息
DHCP服务器收到客户端的请求,验证是否来至合法的PXE 客户端的请求,验证通过它将给客户端一个“提供”响应,这个“提供”响应中包含了为客户端分配的IP地址、pxelinux启动程序(TFTP)位置,以及配置文件所在位置。
③ PXE****客户端请求下载启动文件
客户端收到服务器的“回应”后,会回应一个帧,以请求传送启动所需文件。这些启动文件包括:pxelinux.0、pxelinux.cfg/default、vmlinuz、initrd.img等文件。
④ TETP****服务器响应客户端请求并传送文件
当服务器收到客户端的请求后,他们之间之后将有更多的信息在客户端与服务器之间作应答, 用以决定启动参数。BootROM由TFTP通讯协议从tftp服务器 下载启动安装程序所必须的文件(pxelinux.0、pxelinux.cfg/default)。default文件下载完成后,会根据该文件中定义的引导顺序,启动Linux安装程序的引导内核。
⑤ 请求下载自动应答文件
客户端通过pxelinux.cfg/default文件成功的引导Linux安装内核后,安装程序首先必须确定你通过什么安装介质来安装linux,如果是通过网络安装(NFS, FTP, HTTP),则会在这个时候初始化网络,并定位安装源位置。接着会读取default文件中指定的自动应答文件ks.cfg所在位置,根据该位置请求下载该文件。
⑥ 客户端安装操作系统
将ks.cfg文件下载回来后,通过该文件找到http镜像,并按照该文件的配置请求下载安装过程需要的软件包。
http镜像和客户端建立连接后,将开始传输软件包,客户端将开始安装操作系统。
1.3 kickstart批量安装系统实践
一般批量安装操作系统最好一次安装23台机器最佳,主要因为大部分交换机为24口,安装23台服务器没有太大的压力
1.3.1 环境说明
防火墙与selinux****必须关闭。
[root@kickstart ~]# uname -r 3.10.-693.el7.x86_64
[root@kickstart ~]# getenforce Disabled
[root@kickstart ~]# systemctl status firewalld.service ● firewalld.service - firewalld - dynamic firewall daemon Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled) Active: inactive (dead) Docs: man:firewalld(1)
[root@kickstart ~]# hostname -I 10.0.0.201 172.16.1.201
1.3.2 第一个里程碑:安装dhcp服务
安装
配置DHCP__服务
配置文件说明:
启动DHCP__服务
检测端口信息
_查看其日志信息: (_日志位置为/var/log/messages)
注:配置dhcp的时候是可以配置监听的网卡,指定监听网卡
1.3.3 创建一个新的空白虚拟机
说明:Centos7.3之后安装系统至少需要2G内存,低于2G****将无法安装
开启虚拟机
日志输出
1.3.4 安装tftp服务
安装tftp__软件
启动服务
tftp****根目录
再次启动虚拟机
启动发现又tftp但是没找到要加载的系统。上面报错是在TFTP服务的根目录找不到启动文件pxelinux.0
1.3.5 获取pxelinux.0系统
通过安装软件获得
复制pxelinux.0文件到tftp根目录
首先排除最简单故障原因:selinux是否关闭,防火墙是否关闭
上面的错误是因为pxelinux.0这个小系统的**配置文件(default)**不存在,或者文件名不对
1.3.6 添加pxelinux.0配置文件
1)给虚拟机添加上centos7的镜像,注意实在kickstart服务端添加
2)将镜像挂载上
**特别说明:**由于这是测试环境可以使用挂载,在生产环境中必须把镜像中的文件复制到硬盘上,光驱速度太慢。
3)将镜像中的相关文件复制到tftp根目录
4)修改default配置文件实现通过网络安装操作系统
CentOS7.X 网络安装的关键点,修改default文件
修改完成后,重启pxe客户端,就会有安装界面,与使用光盘安装一致,这里就不是做详细的记录了。注意实现网路安装需要将下一步完成_(配置http服务_)。
5)CentOS7实现自动化安装的default文件
label ks kernel vmlinuz append initrd=initrd.img ks=http://172.16.1.201/ks_config/CentOS7-ks.cfg net.ifnames=0 biosdevname=0 ksdevice=eth1
1.3.7 配置httpd服务
安装apache__服务
启动apache__服务
通过浏览器访问,使用curl__命令镜像访问。
1.4 ks文件说明
1.4.1 ks文件的作用
通常,我们在安装操作系统的过程中,需要大量的和服务器交互操作,为了减少这个交互过程,kickstart就诞生了。使用这种kickstart,只需事先定义好一个Kickstart自动应答配置文件ks.cfg(通常存放在安装服务器上),并让安装程序知道该配置文件的位置,在安装过程中安装程序就可以自己从该文件中读取安装配置,这样就避免了在安装过程中多次的人机交互,从而实现无人值守的自动化安装。
1.4.2 ks文件生成的三种方式
方法1
每安装好一台Centos机器,Centos安装程序都会创建一个kickstart配置文件,记录你的真实安装配置。如果你希望实现和某系统类似的安装,可以基于该系统的kickstart配置文件来生成你自己的kickstart配置文件。(生成的文件名字叫anaconda-ks.cfg位于/root/anaconda-ks.cfg)
方法2
Centos提供了一个图形化的kickstart配置工具。在任何一个安装好的Linux系统上运行该工具,就可以很容易地创建你自己的kickstart配置文件。kickstart配置工具命令为redhat-config-kickstart(RHEL3)或system-config-kickstart(RHEL4,RHEL5).网上有很多用CentOS桌面版生成ks文件的文章,如果有现成的系统就没什么可说。但没有现成的,也没有必要去用桌面版,命令行也很简单。
方法3
阅读kickstart配置文件的手册。用任何一个文本编辑器都可以创建你自己的kickstart配置文件。
1.4.3 centos7.4自动应答文件(ks)
%packages #包组段 @表示包组 @^minimal @compat-libraries @debugging @development tree nmap sysstat lrzsz dos2unix telnet wget vim bash-completion %end
%post #脚本段,可以放脚本或命令 systemctl disable postfix.service #关闭邮件服务开机自启动 %end
1.4.4 PXE配置文件default
由于多个客户端可以从一个PXE服务器引导,PXE引导映像使用了一个复杂的配置文件搜索方式来查找针对客户机的配置文件。如果客户机的网卡的MAC地址为8F:3H:AA:6B:CC:5D,对应的IP地址为10.0.0.195,那么客户机首先尝试以MAC地址为文件名匹配的配置文件,如果不存在就以IP地址来查找。根据上述环境针对这台主机要查找的以一个配置文件就是 /tftpboot/pxelinux.cfg/01-8F:3H:AA:6B:CC:5D。如果该文件不存在,就会根据IP地址来查找配置文件了,这个算法更复杂些,PXE映像查找会根据IP地址16进制命名的客户机配置文件。例如:10.0.0.195对应的16进制的形式为C0A801C3。(可以通过syslinux软件包提供的gethostip命令将10进制的IP转换为16进制)
如果C0A801C3文件不存在,就尝试查找C0A801C文件,如果C0A801C也不存在,那么就尝试C0A801文件,依次类推,直到查找C文件,如果C也不存在的话,那么最后尝试default文件。
总体来说,pxelinux搜索的文件的顺序是:
1.4.5 上面的事情做完以后就可以批量安装系统了
[root@Cobbler ~]# systemctl status firewalld.service ● firewalld.service - firewalld - dynamic firewall daemon Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled) Active: inactive (dead) Docs: man:firewalld(1)
[root@Cobbler ~]# getenforce Disabled
[root@Cobbler ~]# hostname -I 10.0.0.202 172.16.1.202
1.5 常见错误
1.5.1 网卡无法启动解决
解决办法:
将NetworkManager服务停止,再重新启动network服务
[root@CentOS7 ~]# systemctl stop NetworkManager
1.5.2 Could not find kernel image
1.5.3 查考文档
<li>
<a href="#13_kickstart">1.3 kickstart批量安装系统实践</a><ul>
<li>
<a href="#131">1.3.1 环境说明</a>
</li>
<li>
<a href="#132_dhcp">1.3.2 第一个里程碑:安装dhcp服务</a>
</li>
<li>
<a href="#133">1.3.3 创建一个新的空白虚拟机</a>
</li>
<li>
<a href="#134_tftp">1.3.4 安装tftp服务</a>
</li>
<li>
<a href="#135_pxelinux0">1.3.5 获取pxelinux.0系统</a>
</li>
<li>
<a href="#136_pxelinux0">1.3.6 添加pxelinux.0配置文件</a>
</li>
<li>
<a href="#137_httpd">1.3.7 配置httpd服务</a>
</li>
</ul>
</li>
<li>
<a href="#14_ks">1.4 ks文件说明</a><ul>
<li>
<a href="#141_ks">1.4.1 ks文件的作用</a>
</li>
<li>
<a href="#142_ks">1.4.2 ks文件生成的三种方式</a>
</li>
<li>
<a href="#143_centos74ks">1.4.3 centos7.4自动应答文件(ks)</a>
</li>
<li>
<a href="#144_PXEdefault">1.4.4 PXE配置文件default</a>
</li>
<li>
<a href="#145">1.4.5 上面的事情做完以后就可以批量安装系统了</a>
</li>
</ul>
</li>
<li>
<a href="#15">1.5 常见错误</a><ul>
<li>
<a href="#151">1.5.1 网卡无法启动解决</a>
</li>
<li>
<a href="#152_Could_not_find_kernel_image">1.5.2 Could not find kernel image</a>
</li>
<li>
<a href="#153">1.5.3 查考文档</a>
</li>
</ul>
</li>
- 原文作者:惨绿少年
- 原文链接:https://clsn.io/clsn/lx797.html
- 版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。