使用 PXE+Kickstart 实现无人值守批量部署系统
一、废话两句
在云数据中心,一次几十台甚至几百台服务器上线,系统安装将变得非常繁琐,系统安装好了后还会涉及很多配置,如果一台台来安装的话工作量非常大。(虽然有加班费,开个玩笑)
为了解决这个问题,我们需要实现无人值守批量部署系统。
简单看一下拓扑图:
1. 什么是PXE?
简单来说:PXE主要是引导作用,具体的详细信息这里就不多说了,详情百度即可。
PXE引导流程:
2. 什么是Kickstart?
简单两句就是:Kickstart是一种无人值守的安装方式。它的工作原理是在安装过程中记录典型的需要人工干预填写的各种参数;
比如:我们安装系统的时候需要分区、设置时区、设置root密码、安装后执行的脚本等等,这些操作都记录下来并生成一个名为ks.cfg的文件。
PXE+Kickstart 无人值守安装操作系统完整过程:
二、环境准备
操作系统:CentOS 7.4 (最小化安装)
实验平台:VMware Workstation 14
网络模式:NAT模式
服务器IP地址:192.168.115.21
防火墙:关闭
SElinux=Disable
三、准备工作
如果当初已经是图形化安装了,则不需要该步骤。
生成ks.cfg 文件需要system-config-kickstart 工具,而此工具依赖于X Windows,所以我们需要安装X Windows 和Desktop 并重启系统,操作如下:
i. 挂载光盘:
[root@localhost ~]# mkdir /mnt/cdrom
[root@localhost ~]# mount /dev/cdrom /mnt/cdrom
ii. 配置本地yum源:
[root@localhost ~]# cat /etc/yum.repos.d/dvd.repo
------------------------------------------------------
[development]
# 名称必须为 “development”,否则到后面kickstart配置会出现软件包选择出现没有软件包信息
name=redhat
baseurl=file:///mnt/cdrom
gpgcheck=
iii. 安装图形化:
[root@localhost ~]# yum groupinstall "Server with GUI" -y
[root@localhost ~]# systemctl set-default graphical.target // 设置默认启动到图形界面
[root@localhost ~]# reboot // 重启机器
四、安装需要服务
1. 配置DHCP
i. 安装DHCP服务
[root@localhost ~]# yum install dhcp -y
ii. 修改/etc/dhcp/dhcpd.conf 配置文件
[root@localhost ~]# vim /etc/dhcp/dhcpd.conf
------------------------- 配置如下 -------------------------------
subnet 192.168.115.0 netmask 255.255.255.0 { //所在网段
range 192.168.115.100 192.168.115.199; //分配IP地址范围
option subnet-mask 255.255.255.0; //给客户端设置子网掩码(netmask)
default-lease-time ; //设置默认的IP租期时间
max-lease-time ; //设置最大的IP租期时间
next-server 192.168.115.21; //tfp服务端IP地址
filename "/pxelinux.0"; //网络引导程序
}
iii. 启动DHCP服务
[root@localhost ~]# systemctl start dhcpd
[root@localhost ~]# systemctl enable dhcpd
iv. 测试DHCP是否成功
新建一个虚拟机进行测试,如下图可以看出已经成功获取IP地址和其他信息了。
2. 配置TFP
i. 安装TFP、Xinetd
[root@localhost ~]# yum install tftp-server xinetd -y
ii. 修改配置文件
[root@localhost ~]# vim /etc/xinetd.d/tftp
-------------- 省略配置信息,看下图 -------------
将 disable 设置为 no
iii. 启动服务
因为 tftp 服务是挂载在超级进程 xinetd 下的,所以通过启动 xinetd 来启动 tftp 服务。
[root@localhost ~]# systemctl start xinetd
[root@localhost ~]# systemctl enable xinetd
iv. 检查服务是否启动成功
[root@localhost ~]# netstat -ntulp | grep
udp 0.0.0.0: 0.0.0.0:* /xinetd
3. 安装Syslinux
i. 安装syslinux只是为了要 pxelinux.0 引导加载程序,没有别的用意。
[root@localhost ~]# yum install selinux -y
ii. 复制pxelinux.0 文件至/var/lib/tftpboot/ 文件夹中
[root@localhost ~]# cp /usr/share/syslinux/pxelinux. /var/lib/tftpboot/
iii. 拷贝光盘里的配置文件
[root@localhost ~]# cp /mnt/cdrom/isolinux/* /var/lib/tftpboot/
iv. 验证改步骤是否成功
将新建的测试虚拟机重启,就可以看到该界面了。
4. 配置HTTP
i. 安装HTTP
系统的安装方式可以选择HTTP、FTP、 NFS,我们这里介绍HTTP方式的安装,其他两种方式的安装,大家可以自行百度。
[root@localhost ~]# yum install httpd -y
ii. 启动HTTP
[root@localhost ~]# systemctl start httpd
[root@localhost ~]# systemctl enable httpd
iii. 复制光盘全部内容至http 的根目录/var/www/html/pub 下
[root@localhost ~]# mkdir /var/www/html/pub
[root@localhost ~]# cp -r /mnt/cdrom/ /var/www/html/pub
iv. 测试改步骤是否成功
5. 配置kickstart
i. 安装kickstart
[root@localhost ~]# yum install system-config-kickstart -y
ii. 在桌面环境下配置Kickstart,生成ks.cfg 文件
[root@localhost ~]# system-config-kickstart
A. 设置语言,键盘,时区,Root密码,安装完毕后重启等。
B. 设置安装方式,这篇文章介绍的是HTTP方式的安装。
C. 安装MBR
D. 设置分区
E. 配置网络
F. 认证配置
G. SELinux 和防火墙配置
H. 图形环境配置
I. 软件包安装选择
注:如果你的软件列表没有信息,解决该问题看后面部分,如下图:
J. 安装后脚本
K. 保存导出配置文件
iii. 复制到HTTP下的ks目录
[root@localhost ~]# mkdir /var/www/html/ks
[root@localhost ~]# cp ks.cfg /var/www/html/ks/
iv. 验证改步骤
6. 修改default
i. 创建配置文件夹
[root@localhost ~]# cd /var/lib/tftpboot/
[root@localhost tftpboot]# mkdir pxelinux.cfg
ii. 复制配置文件
[root@localhost ~]# cp /var/lib/tftpboot/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
[root@localhost ~]# vim /var/lib/tftpboot/pxelinux.cfg/default
----------------------- 修改配置如下 --------------------------
label linux
menu label ^Install PXE+Kickstart_RedHat7
kernel vmlinuz
append initrd=initrd.img ks=http://192.168.115.21/ks/ks.cfg ksdevice=eth0 net.ifnames=0 biosdevname=0
参数解释:
append initrd=initrd.img ks // 存放ks配置文件的服务器地址和路径,通过该路径找到对应的ks.cfg文件来引导系统安装
ksdevice=eth0 // 指定该网卡进行ks的数据交互(可忽略)
net.ifnames= biosdevname= // 修改内核参数,让网卡命名变为ethXX
iii. 开机验证(需要手动选择安装)
iv. 全自动化安装,无需手动选择安装
[root@localhost ~]# vim /var/lib/tftpboot/pxelinux.cfg/default
--------------------------------------------------------------
default linux # 在配置文件第一行找到default,加上label的名称即可。
label linux
menu label ^Install PXE+Kickstart_RedHat7
kernel vmlinuz
append initrd=initrd.img ks=http://192.168.115.21/ks/ks.cfg ksdevice=eth0 net.ifnames=0 biosdevname=0
v. 安装好后验证脚本信息
到此就完成了无人值守批量部署系统,收工下班。
五、你可能会出现的问题
1. 配置kickstart时,软件包选择出现没有软件包信息,如下图:
解决办法:
检查yum源配置是否为: [development] ,配置好后,重新打开kickstart配置窗口即可。如图:
2. 配置好后,进行自动化部署的时候出现如下报错信息,如下图:
"/sbin/dmsquash-live-root: line 273: write error: No space left on device"
解决办法:
检查虚拟机或服务器的内存大小,RedHat7.3以上的版本进行Kickstart安装需要分配至少2GB的内存。
使用 PXE+Kickstart 实现无人值守批量部署系统的更多相关文章
- pxe+kickstart实现无人值守批量安装linux
pxe+kickstart实现无人值守批量安装linux 实验准备:主机myrhel2作为服务器端,新建一个没有安装操作系统的虚拟主机,而且其与服务器端在同一个网段 安装的条件: 服务器端: ...
- 【Linux】使用 PXE+Kickstart 无人值守批量安装系统
一.PXE背景知识 通过 PXE+DHCP+TFTP+VSftpd+Kickstart 服务程序搭建出无人值守安装系统,从而批量部署客户机系统. PXE(Preboot eXecute Environ ...
- pxe+kickstart cobbler无人值守装机
环境准备: 一台服务器 [root@admin tftpboot]# cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core) [roo ...
- 【转载】批量部署系统之kickstart
一.安装各服务: ftp服务提供软件软件源,tftp提供引导文件,dhcp提供PXE文件位置,syslinux提供PXE文件 [root@node1~]# yum -y installtftp-ser ...
- PXE+kickstart网络安装CentOS7.4系统及过程中各种报错
环境:关闭防火墙.selinux 注意:虚拟机进行网络安装的话,7.3以后的系统是需要2G以上的内存 [root@kickstart ~]# cat /etc/redhat-release CentO ...
- PXE+kickstart无人值守安装CentOS 7
kickstart+cobbler系列文章:http://www.cnblogs.com/f-ck-need-u/p/7048359.html 本文是PXE+kickstart无人值守安装CentOS ...
- (转)PXE+kickstart无人值守安装CentOS 7
kickstart+cobbler系列文章:http://www.cnblogs.com/f-ck-need-u/p/7048359.html 本文是PXE+kickstart无人值守安装CentOS ...
- (转)Cobbler无人值守批量安装Linux系统
本文目录: 1.1 pxe安装系统 1.2 cobbler基本介绍 1.3 安装和配置cobbler 1.3.1 安装cobbler 1.3.2 配置dhcp和tftp 1.4 cobbler从本地光 ...
- 第19章 使用PXE+Kickstart部署无人值守安装
章节概述: 本章节将教会您通过PXE+DHCP+TFTP+VSftpd+Kickstart服务程序搭建出无人值守安装系统,从而批量部署客户机系统. 这种系统能够实现自动化运维.避免了重复性劳动,帮助提 ...
随机推荐
- 3. 海思Hi3519A MPP从入门到精通(三 视频输入)
视频输入(VI)模块实现的功能:通过 MIPI Rx(含 MIPI 接口.LVDS 接口和 HISPI 接 口),SLVS-EC,BT.1120,BT.656,BT.601,DC 等接口接收视频数据. ...
- CodeForces - 1251E2 (思维+贪心)
题意 https://vjudge.net/problem/CodeForces-1251E2 一共有 n 个选民,你可以付出 pi 的代价让第 i 个选民为你投票,或者,在为你投票的人数达到 mi ...
- CodeForces - 1248D1 (思维+暴力)
题意 有一个括号序列,你可以选择两个位置i,j(i可以等于j),进行交换.使得最后的循环位置(i的数目)最大. 循环位置:i(0<=i<len),将前i个字符移到最后,得到的新序列是合法的 ...
- index-css-添加类-移除类-toggleClass-attr
1=>index()会返回当前元素在所有的兄弟元素里面的索引值用法:$("a").click(function(){ console.log($(this).index()) ...
- Java实现单词自定义排序|集合类、工具类排序、comparable、comparator接口
课题 针对单词进行排序,先按字母的长度排序,长者在前: 在长度相等的情况下,按字典降序排序. 例如,有单词序列"apple banana grape orange",排序后输出结果 ...
- 201271050130-滕江南-《面向对象程序设计(java)》第十五周学习总结
201271050130-滕江南-<面向对象程序设计(java)>第十五周学习总结 博文正文开头格式:(2分) 项目 内容 这个作业属于哪个课程 https://www.cnblogs.c ...
- 1【西北师大-2108Java】第一次作业成绩汇总
[西北师大-2108Java]第一次作业成绩汇总 经过本次作业的练习,了解了Java最基本的知识和Java的发展:了解了Java到底是一门怎样的语言,也知道了学习Java的乐趣,懂得了去选择Java开 ...
- [转] 构建Docker镜像两种方式的比较-Dockerfile方式和S2I方式
原文地址:https://www.cnblogs.com/tianshifu/p/8127837.html 前言 写Dockerfile是构建Docker镜像最通常的方式,接触过Docker的童鞋多少 ...
- 洛谷 P4316 绿豆蛙的归宿
洛谷 P4316 绿豆蛙的归宿 洛谷传送门 题目背景 随着新版百度空间的上线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 题目描述 给出一个有向无环图,起点为1终点为N,每条边都有一个长度, ...
- 项目倒入maven 遇到的问题只有 main 了
归根结底是倒入错了: (1)首先 view->Toolbar; (2) 点击 File==>project structure 然后:在 project settings中点击 modu ...