PXE KICKSTART 全自动安装系统

一、PXE PXE(Pre-boot Execution Environment,预启动执行环境) 在Client/Server的网络模式下,通过网络从远端服务器下载映像,并通过网络启动操作系统。启动过程中,终端要求dhcp服务器分配IP地址,再用TFTP(trivial file transfer protocol)协议下载一个启动软件包到本机内存中执行,由这个启动软件包完成终端基本软件设置,从而引导预先安装在服务器中的终端操作系统。

二、PXE的工作流程

152331542808644.jpg

1.PXE Client 从自己的PXE网卡启动,向本网络中的DHCP服务器索取IP;

2.DHCP 服务器返回分配给客户机的IP 以及PXE文件的放置位置(该文件一般是放在一台TFTP服务器上) ;

3.PXE Client 向本网络中的TFTP服务器索取pxelinux.0 文件;

4.PXE Client 取得pxelinux.0 文件后之执行该文件;

5.根据pxelinux.0 的执行结果,通过TFTP服务器加载内核和文件系统 ;

6.进入安装画面, 此时可以通过选择HTTP方式之一进行安装;

三、DHCP服务器
DHCP是一个基于UDP的工作在应用层的协议,用来自动分配IP地址。

提供的服务有:
1.提供IP地址和子网掩码
2.提供IP地址对应的网络地址和广播地址
3.默认网关地址
4.DNS服务器地址

租约时间:
DHCP分配给客户的IP是以租约形式分配的。当客户接入到网络中,DHCP便会分配一个IP给客户机,当租约时间到的时候如果客户机还在使用这个IP那么就可以续约,继续使用当前IP而不是从新分配一个。

安装DHCP服务器
<code># yum -y install dhcpd</code>

配置DHCP服务
<code># vim /etc/dhcp/dhcpd.conf</code>
<code>
ddns-update-style interim;#设置DHCP于DNS服务器的动态信息更新模式。初学时完全可以不理这个选项,但是全局设置中一定要有这个选项,否则DHCP服务不能成功启动。
ignore client-updates; #忽略客户端更新
option domain-name-servers 114.114.114.114, 8.8.8.8; #设置DNS服务器地址#下面开始分配子网,网段是172.16.0.0 子网掩码是 255.255.0.0#不能理解网段和子网掩码的可以去网上查一下。简单的说网段规定了分配IP的段(分配哪一段IP给客户机),子网掩码规定了网段的大小
subnet 172.16.0.0 netmask 255.255.0.0 {#range 172.16.5.212 192.168.5.215; #分配给客户机的IP从172.16.5.212开始到 172.16.5.215
option broadcast-address 172.16.255.255; #广播地址
option routers 172.16.1.1; #设置网关 default-lease-time 600; #默认租约时间
max-lease-time 7200; #最大租约时间 next-server 172.16.5.135; #dhcp ip地址
filename "pxelinux.0"; #PXE文件
}
host centos7 { #主机名为centos7
hardware ethernet 08:00:27:5e:04:27; #MAC地址是08:...:27的网卡
fixed-address 172.16.5.136; #分配给它172.16.5.136的IP
}# 只要这个CLient_C接入到了这个网络中,那么它获取的IP就是固定的这一个,并不会变
</code>

重启DHCP服务
<code># systemctl restart dhcpd.service</code>

四、TFTP服务器 TFTP(Trivial File Transfer Protocol,简单文件传输协议)是TCP/IP协议族中的一个用来在客户机与服务器之间 进行简单文件传输的协议,提供不复杂、开销不大的文件传输服务。端口号为UDP的69号端口。
安装tftp-server 、xinetd
<code>#yum –y install tftp-server xinetd</code>

启用TFTP服务, vi /etc/xinetd.d/tftp
将disable 设置为no 启动TFTP服务,systemctl start xinetd

五、HTTP服务 HTTP协议定义Web客户端如何从Web服务器请求Web页面,以及服务器如何把Web页面传送给客户端。HTTP协议采用了请求/响应模型。 1、安装软件: yum -y install httpd 2、启动服务:systemctl start httpd 3、设置开机启动: systemctl enable httpd
将iso文件挂载至/var/www/html/os/
<code># mount -t iso9660 -o loop /image/os/CentOS-7-x86_64-DVD-1611.iso /var/www/html/os</code>

六、配置支持PXE的启动程序 获取pxelinux.0 文件
<code># cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/</code>

复制iso 镜像中的/image/pxeboot/initrd.img 和vmlinux 至/var/lib/tftpboot/ 文件夹中
<code># cp /var/www/html/os/images/pxeboot/{initrd.img,vmlinuz} /var/lib/tftpboot/</code>

复制iso 镜像中的/isolinux/.msg 至/var/lib/tftpboot/ 文件夹中
<code># cp /var/www/html/cdrom/isolinux/
.msg /var/lib/tftpboot/</code>

复制vesamenu.32c的作用就是启动菜单外观绘制拓展工具
<code># cp /cgls/vesamenu.32c /var/lib/tftpboot/</code>

在/var/lib/tftpboot/ 中新建一个pxelinux.cfg目录
<code># mkdir /var/lib/tftpboot/pxelinux.cfg</code>

将iso 镜像中的/isolinux 目录中的isolinux.cfg复制到pxelinux.cfg目录中,同时更改文件名称为default
<code># cp /var/www/html/cdrom/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default</code>

修改default文件
<code># vi /var/lib/tftpboot/pxelinux.cfg/default</code>
<code>
default vesamenu.c32 #引入菜单外观绘制拓展工具
prompt 0
timeout 100
display boot.msg
menu clear #菜单颜色
menu background splash.png
menu title CentOS 7
menu vshift 8
menu rows 18
menu margin 8
menu helpmsgrow 15
menu tabmsgrow 13
menu color border * #00000000 #00000000 none
menu color sel 0 #ffffffff #00000000 none
menu color title 0 #ff7ba3d0 #00000000 none
menu color tabmsg 0 #ff3a6496 #00000000 none
menu color tabmsg 0 #ff3a6496 #00000000 none
menu color hotsel 0 #84b8ffff #00000000 none
menu color hotkey 0 #ffffffff #00000000 none
menu color help 0 #ffffffff #00000000 none
menu color scrollbar 0 #ffffffff #ff355594 none
menu color scrollbar 0 #ffffffff #ff355594 none
menu color cmdmark 0 #84b8ffff #00000000 none
menu color cmdline 0 #ffffffff #00000000 none
menu tabmsg Press Tab for full configuration options on menu items.
menu separator # insert an empty line
menu separator # insert an empty line
label linux #菜单选项
menu label ^Install CentOS 7
kernel vmlinuz
append initrd=initrd.img inst.repo=http://172.16.5.135/os/ net.ifnames=0 biosdevname=0

label ks
menu label ^Auto Install CentOS 7
menu default
kernel vmlinuz
append ks=http://172.16.5.135/ks.cfg initrd=initrd.img net.ifnames=0 biosdevname=0

menu separator # insert an empty line
</code>
七、编写ks.cfg
<code>#vi /var/www/html/ks.cfg </code>
<code>

version=RHEL7

System authorization information

auth --enableshadow --passalgo=sha512

Install OS instead of upgrade

install

Reboot after installation

reboot

Use network installation

url --url=http://172.16.5.135/os/ ##这个选项告诉安装程序:到服务器192.168.111.130 的HTTP根目录下的cdrom 文件夹下寻找安装介质

Use graphical install

graphical

Firewall configuration

firewall --enabled --port=22:tcp

Keyboard layouts

keyboard --vckeymap=us --xlayouts='us'

System language

lang en_US.UTF-8

Network information

%include /tmp/network

Root password

rootpw 123qwe

rootpw --iscrypted $6$CD2GJykfp0S72QWl$mF26Q1QMkg1QubquxOTulUKJ6MhhXPuJ8xNU0nWM0HU2Wd/BItPOKY6BdOo03IX9umtykJuRKEiy2yf51dOuQ1

SELinux configuration

selinux --disabled

System timezone

timezone Asia/Shanghai --isUtc

System bootloader configuration

Partition clearing information

Clear the Master Boot Record

Disk partitioning information

%include /tmp/disk

%pre --logfile /tmp/ks-pre.log

!/bin/sh

Disk partitioning

declare -a disks

echo "clearpart --all" > /tmp/disk

echo "clearpart --none" > /tmp/disk
echo "zerombr" >> /tmp/disk

disks=(fdisk -l | grep "^Disk /dev/[s,h,v]d" | awk -F ' |:' '{print $2}')
disks=(echo ${disks[@]} | xargs -n 1 | sort -k 1.8)
len=${#disks[@]}
diskstr=""
for ((i=0;i<$len;i++))
do
parted -s ${disks[$i]} mklabel gpt
partprobe ${disks[$i]}
dev=basename ${disks[$i]}
if [ $i -eq 0 ]; then
echo "part biosboot --fstype=biosboot --ondisk=$dev --size=1" >> /tmp/disk
echo "part /boot --fstype=xfs --ondisk=$dev --size=300" >> /tmp/disk
echo "part swap --fstype=swap --ondisk=$dev --recommended" >> /tmp/disk

echo "part / --fstype=xfs --ondisk=$dev --size=204800" >> /tmp/disk

    echo "part / --fstype=xfs --ondisk=$dev --grow" >> /tmp/disk
            echo "bootloader --location=mbr --boot-drive=$dev" >> /tmp/disk
    diskstr=$dev
else
    echo "part /disk$i --fstype=xfs --ondisk=$dev --grow" >> /tmp/disk
    diskstr=$diskstr,$dev
fi

done

echo "ignoredisk --only-use=$diskstr" >> /tmp/disk

Network configuration

declare -a nics
nicstr=grep : /proc/net/dev | awk -F : '{print $1}'
nics=(${nicstr/lo/})

/tmp/network
len=${#nics[@]}
for ((i=0;i<$len;i++))
do
nic=${nics[$i]}
echo "network --bootproto=dhcp --device=$nic --onboot=on --ipv6=auto" >> /tmp/network
done

%end

%packages
@^infrastructure-server-environment
@base
@core
kexec-tools

%end

%addon com_redhat_kdump --enable --reserve-mb='auto'

%end
</code>

重启所有服务
<code># systemctl restart xinetd</code>
<code># systemctl restart httpd </code>
<code># systemctl restart dhcpd</code>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容