自动化光盘启动部署服务器
这里是通过虚拟机进行实际部署前的测试,完全可用于实际的部署工作,完成后可实现一张自制启动光盘和一台可装有HTTP和DHCP服务的linux系统服务器自动化安装操作系统。
虚拟环境:
操作系统 rhel-server-5.4-x86 IP:192.168.1.3
客户端需要安装的系统:rhel-server-5.4-x86
NOTICE:网络自动化安装操作系统,需要客户端支持网卡启动和PXE功能。
实施步骤:
一、配置DHCP服务器:
1)安装DHCP服务器
[root@rrl ~]#yum install -y dhcp*
2)编辑DHCP服务器配置文件/etc/dhcp/dhcpd.conf
因目的是安装操作系统,而不是将其作为专门的DHCP服务器,所以只需配置几项简单的参数
ddns-update-style interim;
allow booting;
allow bootp;
ignore client-updates;
set vendorclass = option vendor-class-identifier;
subnet 192.168.1.0 netmask 255.255.255.0 {
option routers 192.168.1.1;
# option domain-name "ns.rrl.com";
# option domain-name-servers 192.168.1.1;
option subnet-mask 255.255.255.0;
range dynamic-bootp 192.168.1.100 192.168.1.199;
filename "/pxelinux.0";
default-lease-time 21600;
max-lease-time 43200;
next-server 192.168.1.3;
}
简单介绍:
Option routers指定网关;
Option domain-name-server指定DNS服务器;
Option subnet-mask指定掩码;
range dynamic-bootp指定分配给客户端的IP地址段;
Filename 指定启动镜像;
Next-server 指定TFTP服务器。
将DNS配置注释掉,因在安装某些版本的红帽系统时,会需要指定的DNS服务器进行解析,从而导致自动化安装失败。
3)启动DHCP服务
[root@rrl ~]#service dhcpd start
[root@rrl ~]#chkconfig --add dhcpd #设置dhcp服务开机自动启动
4)查看已分配的DHCP地址
[root@rrl ~]#cat /var/lib/dhcp/dhcpd.leases lease 192.168.1.199 { starts 4 2016/12/08 08:13:17; ends 4 2016/12/08 14:13:17; binding state active; next binding state free; hardware ethernet 00:50:56:9c:7b:a5; client-hostname "jacktest"; }
二、配置WEB服务器
1)安装httpd服务器
[root@rrl~]#yum install –y httpd*
2)配置Web服务器
通过yum安装的httpd服务器网页文件放置的位置在/var/www/html目录中。我们在这个目录中创建rhel5.4镜像的挂载目录。然后将镜像重新挂载到这个目录下。
[root@rrl~]#mkdir /var/www/html/rhel5.4 [root@rrl~]#umount /media/iso [root@rrl~]#mount –o loop,ro rhel-server-5.4-i386-dvd.iso /var/www/html/rhel5.4
3)启动httpd服务器
[root@rrl~]#service httpd start [root@rrl~]#chkconfig --add httpd #设置httpd服务开机自动启动
在这个阶段我们也可以使用NFS或者FTP的方式进行部署,配置过程同样很简单。只需要执行几个命令并且修改对应的kickstart文件中的如何指定安装树的指向的配置选项。在下面kickstart文件中我会给出nfs和ftp的指向配置,可以参考一下。
三、配置kickstart文件
三种方式创建kickstart文件
1.1.System-config-kickstart方式:这需要我们事先安装好syste-config-kickstart软件包,使用yum安装即可。然后使用这个软件定制我们的kickstart文件;
[root@test ~]# yum install system-config-kickstart.noarch
[root@test ~]# ksvalidator /root/anaconda-ks.cfg #检查文件错误
[root@test ~]# timeconfig
[root@test ~]# system-config-kickstart & #图形化生成/root/class.cfg文件
1.2复制/root/anaconda-ks.cfg文件方式:
因Red Hat操作系统,在系统安装完成后,会自动在root家目录下创建一个anaconda-ks.cfg文件,这个文件真实的记录了系统安装过程中的配置。我们可以复制这个文件,然后在其基础上进行配置。
[root@test ~]# mount /dev/cdrom /media # 将安装光盘mount到/media
[root@test p_w_picpaths]# ls /media/p_w_picpaths
README TRANS.TBL boot.iso diskboot.img minstg2.img pxeboot stage2.img xen
[root@test p_w_picpaths]# cp /media/p_w_picpaths/boot.iso /root/
[root@test ~]# ls /root/
boot.iso
[root@test ~]# mount -o loop boot.iso /mnt/cdrom/ # 将该文件mount到/mnt/cdrom/
[root@test ~]# cd /mnt/cdrom/
[root@test cdrom]# ls
TRANS.TBL isolinux
[root@test isolinux]# ls /mnt/cdrom/isolinux/
TRANS.TBL boot.msg initrd.img isolinux.cfg options.msg rescue.msg vmlinuz
boot.cat general.msg isolinux.bin memtest param.msg splash.lss
[root@test ~]# mv class.cfg ks.cfg #更改后的ks.cfg文件如附件
[root@test tmp]# mkdir iso
[root@test tmp]# cd iso/
[root@test iso]# cp /mnt/cdrom/* ./ -r #将/mnt/cdrom内容复制到当前目录中
[root@test iso]# ls
TRANS.TBL isolinux
[root@test iso]# cd isolinux/
[root@test isolinux]# ls
TRANS.TBL boot.msg initrd.img isolinux.cfg options.msg rescue.msg vmlinuz
boot.cat general.msg isolinux.bin memtest param.msg splash.lss
[root@test iso]# cp /root/class.cfg ./ks.cfg
[root@test iso]# ls
TRANS.TBL isolinux ks.cfg
[root@test iso]# chmod +r /root/ks.cfg
[root@test iso]# ll /root/ks.cfg
-rw-r--r-- 1 root root 2064 Dec 7 09:51 /root/ks.cfg
[root@test isolinux]# vim isolinux.cfg
default linux ks=cdrom:/ks.cfg #红色为新增部分,表示光盘启动
[root@test isolinux]# vi /tmp/iso/isolinux/boot.msg #编辑此文件后显示如下图
^L
^Xsplash.lss
- To install or upgrade in graphical mode, press the ^O01<ENTER>^O07 key.
XXX
- To install or upgrade in text mode, type: ^O01linux text <ENTER>^O07.
XXX
- Use the function keys listed below for more information.
XXX
^O0f[F1-Main] [F2-Options] [F3-General] [F4-Kernel] [F5-Rescue]^O07
[root@test isolinux]# ls
TRANS.TBL boot.msg initrd.img isolinux.cfg options.msg rescue.msg vmlinuz
boot.cat general.msg isolinux.bin memtest param.msg splash.lss
[root@test ~]# vi /tftpboot/pxelinux.cfg/default
default linux
prompt 1
timeout 30 #红色部分为已更改
...
append initrd=initrd.img text #因使用光盘访问方式,此处不改
#若此文件通过HTTP访问红色部分改为:ks=http://192.168.1.3/ks.cfg
[root@test isolinux]# cd /tmp #切换到非iso目录
[root@test tmp]#mkisofs -R -b isolinux/isolinux.bin -no-emul-boot -boot-load-size 4 -boot-info-table -o boot.iso iso/
1.3.文件ks.cfg纯手工打造方式,就是自己使用文本工具(如:vi)直接进行编辑配置;
[root@test iso]# cat ks.cfg
# Kickstart file automatically generated by anaconda.
#version=DEVEL
Install
#nfs --server=192.168.1.3 --dir=/media/cdrom
#url --url=ftp://root:root@192.168.1.3/var/ftp
url --url=ftp://192.168.1.3/rhel5.4
lang en_US
langsupport --default en_US en_US
keyboard us
text
key –skip
network –bootproto=dhcp --device=eth0 --onboot=on
rootpw root
# Reboot after installation
reboot
firewall --disabled
authconfig --useshadow --passalgo=sha512
selinux --disabled
timezone Asia/Shanghai
bootloader --location=mbr --driveorder=sda
# The following is the partition information you requested
# Note that any partitions you deleted are not expressed
# here so unless you clear all partitions first, this is
# not guaranteed to work
clearpart --all --initlabel
#part /boot --fstype=ext4 --size=500
#part swap --size=2048
#part / --fstype=ext4 --grow --size=2 # --grow表示剩余的所有空间分配于此
part /boot --bytes-per-inode=4096 --fstype="ext3" --size=1024
part /home --bytes-per-inode=4096 --fstype="ext3" --size=4096
part /tmp --bytes-per-inode=4096 --fstype="ext3" --size=4096
part /usr --bytes-per-inode=4096 --fstype="ext3" --size=4096
part swap --bytes-per-inode=4096 --fstype="swap" --size=2048
part / --bytes-per-inode=4096 --fstype="ext3" --grow --size=1
# X Window System configuration information
xconfig --defaultdesktop=GNOME --depth=16 --resolution=1024x768 --startxonboot
%packages
@Base
@Core
@base
@client-mgmt-tools
@debugging
@emacs
@ftp-server
@hardware-monitoring
@large-systems
@network-file-system-client
openssh
openssh-server
openssh-clients
vim-enhanced
firefox
mutt
screen
NOTICE:红帽5系列与红帽6系列的kickstart文件有点区别,在红帽5系列中如果有%end选项的话,在安装过程中会报错,红帽6.0以后的系统支持该选项。红帽5系列的最高支持ext3文件系统,红帽6系列的最高支持ext4文件系统,所以在kickstart文件中要根据系统的版本进行相应的修改。