一、基本环境 操作系统:CentOS7.4 内核版本:3.10.0-862.11.6.el7.x86_64
二、组件部署 yum安装tftp tftpd-server xinetd http dhcp.
1 yum -y install tftp tftpd-server xinetd http dhcp
安装完成后进行简单必要的配置:
1. tftp守护进程xinetd配置
1 vim /etc/xinetd.d/tftp 2 service tftp { 3 ... 4 disable = yes #这里将“yes"改成“no” 5 ... 6 }
2. dhcp配置
vim /etc/dhcp/dhcpd.conf (dhcpd.conf这个文件没有的话,可以用/usr/share/doc/dhcp-4.2.5/下的模版文件复制一个,再根据自己的实际网络环境,修改其中的IP.
1 subnet 172.16.12.0 netmask 255.255.255.0 { #网络环境,tftp http服务器所在的网段,这里是我的主机网卡. 2 range 172.16.12.140 172.16.12.200; 3 option domain-name-servers 172.16.12.1; 4 option domain-name "dhcp.example.org"; #这个域名可以去掉 5 option routers 172.16.12.1; 6 option broadcast-address 172.16.12.255; 7 default-lease-time 600; 8 max-lease-time 7200; 9 next-server 172.16.12.142; #指定tftp http服务器 10 filename "pxelinux.0"; #指定引导文件 11 }
分别启动 tftp tftpd-server xinetd http dhcp .
关闭防火墙、selinux.
按照系统加电、BIOS引导、内核引导、安装简要说明下:
1. dhcp PXE开机引导下,dhcp负责分配给客户机一个IP地址,这样客户机就有了门牌号码,可以跟网络中的其它主机通信了.
2. tftp 在系统引导阶段向客户机传送引导文件、内核镜像等文件(这时候内核还没在客户机中运行,无法进行HTTP通信).
3. http 内核完全接管客户机,通过HTTP传送IOS,开始安装.
三、准备第一阶段安装文件
首先将centos7.iso的安装镜像挂在到http根目录下,后续将会用到.
1 mount /dev/sr0 /var/www/html/os/
第一阶段文件放在tftpboot目录下,
cd /var/lib/tftpboot/
如上图,initrd.img pxelinux.cfg/default vesamenu.c32 vmlinuz 都直接复制/centos7.iso/isolinux/镜像目录中相应的文件就行了.其中/pxelinux.cfg/default文件复制/cenos7.iso/isolinux/isolinux.cfg重命名为default.
1 cp /var/www/html/os/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default 2 vim /var/lib/tftpboot/pxelinux.cfg/default #修改初始安装界面的菜单
default vesamenu.c32 #默认菜单文件 3 timeout 10 #初始安装菜单界面停留时间,默认是600,我为了省时,改成了10 4 5 menu title CentOS 7 #菜单标题,最好不要改 6 7 label auto 8 menu label ^Auto Install CentOS 7 9 kernel vmlinuz 10 11 12 label manual 13 menu label Test this ^Manual install CentOS 7 14 menu default 15 kernel vmlinuz 16 append initrd=initrd.img inst.repo=http://172.16.12.142:80/os #告诉安装程序,安装镜像在哪里 17 append initrd=initrd.img ks=http://172.16.12.142:80/ks.cfg #这里必须更改成http服务器中ks.cfg文件的路径
18 19 label local 20 menu label Boot from ^local drive 21 localboot 0xffff
pxelinux.0文件在/usr/share/syslinux/pxelinux.0中找到,复制过来就好了.如果/usr/share/下没有syslinux/目录,说明系统没有安装syslinux,yum安装一下就有了.
1 yum -y install syslinux
2 cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
到这里第一阶段文件就准备好了.
四、准备第二阶段安装配置文件,即ks.cfg.
ks.cfg可以用系统自带的kickstart工具生成,但是这个工具不完善,生成的.cfg文件,在安装程序界面无法实现自动应答.这里红帽官方教材推荐的是复制系统自带的root用户目录下的anacond-ks.cfg.
cp /root/anacond-ks.cfg /var/www/html/ks-config/ks.cfg #这里用的centos7自带的anacond-ks.cfg做模版 vim /var/www/html/ks-config/ks.cfg #version=DEVEL auth --enableshadow --passalgo=sha512 url --url=http://172.16.12.142/os/ #安装介质位置 Text #使用文本模式安装界面 firstboot --disable ignoredisk --only-use=sda keyboard --vckeymap=us --xlayouts='us' lang en_US.UTF-8 network --bootproto=dhcp --device=eth0 --activate #网络配置,启用dhcp,激活自动连接 rootpw --iscrypted $6$InOp5eeyMRNQ.XLN$oFLGFfSpMx9CwIQoYsb.gxfpNJfIRGn/mNtI7O.XO6BDCafdT2TImZw0rvSDkaH8Be/XETEWLrQyjsKMTMazJ1 services --disable="chronyd" timezone America/New_York --isUtc xconfig --startxonboot bootloader --location=mbr --boot-drive=sda autopart --type=lvm zerombr #清除磁盘已有的MBR clearpart --all --initlabel --drives=sda part / --fstype="xfs" --ondisk=sda --size=5120 %packages36 @base @core50 @networkmanager-submodules52 @system-admin-tools54 chrony %end %addon com_redhat_kdump --disable --reserve-mb='auto' %end %anaconda pwpolicy root --minlen=6 --minquality=1 --notstrict --nochanges --emptyok pwpolicy user --minlen=6 --minquality=1 --notstrict --nochanges --emptyok pwpolicy luks --minlen=6 --minquality=1 --notstrict --nochanges --emptyok %end %post echo "RUN_FIRSTBOOT=NO" > /etc/sysconfig/firstboot %end
ks.cfg文件可以实际需求更改. 但是有几项是必填的 (1)语言 (2)网络 (3)时区 (4)输入法 (5)ISO源地址 (6)安装包(默认最小模式) (7)分区 (8)root用户密码. 这些都是系统安装过程中要求手动输入的, 所以要实现无人干预全程自动化安装, 这些项目必须事先为安装程序列出.
到这里整个kickstart 所需的文件和服务都准备好了, 开始kickstart吧!