利用DHCP,http,tftp,pxe实现纯自动化安装系统

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用DHCP,http,tftp,pxe实现纯自动化安装系统相关的知识,希望对你有一定的参考价值。

一、实现原理
所需要的服务简单介绍
1.DHCP:动态主机配置协议,用于内部网络自动分配IP地址
2.tfpt:简单的网络共享服务,类似于ftp
3.pxe:支持远程主机通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统
4.http:超文本传输协议,通过网络共享文本(这里也可以使用ftp服务)
实现过程
1.客户端(没有装系统的计算机)通过在局域网内寻找DHCP服务器
2.DHCP服务器回应,发送IP地址给该客户端并且告诉该客户端下一步寻找哪一个服务器,也就是TFTP
3.客户端向TFTP要BootLoader
4.TFTP服务器将pxelinux.0相关文件交给客户端
5.客户端向TFTP服务器要内核文件和initrd.img
6.TFTP将这两个文件路径告诉客户端
7.客户端通过pxe提供的路径向http服务要ks.cfg(自应答文件)
8.客户端根据ks.cfg文件中指定的安装路径寻找安装所需要的文件
二、实现所需要的步骤
1.将虚拟机本身自带的dhcp关闭,并且将充当DHCP服务器主机IP改为静态地址,并且将防火墙和selinux关闭

[[email protected] tftpboot]# nmcli connection modify ens34 ipv4.method manual ipv4.addresses 192.168.0.254/24  #配置网卡信息
[[email protected] tftpboot]# nmcli connection down ens34  #禁用
[[email protected] tftpboot]# nmcli connection up ens34  #启用
[[email protected] tftpboot]# sed -ri ‘s/(SELINUX=).*/\1disabled/‘ /etc/selinux/config   #将selinux设置成关闭
[[email protected] tftpboot]# systemctl stop firewalld.service    #禁用防火墙
[[email protected] tftpboot]# systemctl disable firewalld.service 

2.将虚拟添加3个光驱设备,分别挂载5,6,7三个系统的镜像,为了安装后期所需要的http服务,这里需要临时挂载CentOS 7的光盘镜像

[[email protected] ~]# mount /dev/cdrom /mnt/   #临时挂载
[[email protected] yum.repos.d]# cat /etc/yum.repos.d/base.repo 
[base]
name=base
baseurl=file:///mnt
gpgcheck=0

3.安装自动安装系统所需要的服务

[[email protected] yum.repos.d]# yum install -y httpd dhcp tftp-service syslinux     #安装服务

4.在/var/www/html目录下创建各个版本的挂载路径和自应答文件目录,并且将光盘所对应的目录写入/etc.fstab文件中,使其永久生效

[[email protected] yum.repos.d]# mkdir /var/www/html/centos/{5,6,7,ksdir} #创建对用的文件,对应关系需要根据实际情况
[[email protected] 6]# vim /etc/fstab  
/dev/sr0                                /var/www/html/centos/5    iso9660 defaults        0 0
/dev/sr1                                /var/www/html/centos/6    iso9660 defaults        0 0
/dev/sr2                                /var/www/html/centos/7    iso9660 defaults        0 0

5.创建自应答文件,该文件也可在系统安装完成后,会在/root目录下生成一个anaconda-ks.cfg的文件

[[email protected] tftpboot]# yum install -y system-config-kickstart.noarch   #安装生成自应答文件的工具
[[email protected] tftpboot]system-config-kickstart
[[email protected] ~]# ksvalidator anaconda-ks.cfg #检查该文件语法6 7 通用

注意,在该界面中,若在centos5上创建,仓库的 " [ ] "内需要填写base,centos7中则需要填写development,否则,在Package Selection 界面不会显示选择在安装系统是所需要的软件包 centos6则随意填写

技术分享图片

技术分享图片

技术分享图片

技术分享图片

技术分享图片

软件包根据需要的进行选择,然后保存
6.将三个系统的自应答文件存放到/var/www/html/centos/ksdir/目录下
7.配置DHCP服务器

[[email protected] tftpboot]# cp /usr/share/doc/dhcp*/dhcpd.conf.example /etc/dhcp/dhcpd.conf 
#配置文件
option domain-name "lin.com";     #域名
option domain-name-servers 192.168.0.254;  #
default-lease-time 600;   #租期
max-lease-time 7200;    #用户可调最大
log-facility local7;  #日志文件
subnet 192.168.0.0 netmask 255.255.255.0 {   #自动过去的网段
  range 192.168.0.2 192.168.0.253;    #分发的地址范围
  option routers 192.168.0.254;   #网关 
  next-server 192.168.0.254;   #tftp服务ip
  filename "pxelinux.0";     #找的文件名
}

8.将系统的内核文件和initrd.img文件复制到各个版本的目录下

[[email protected] tftpboot]# mkdir /var/lib/tftpboot/centos{5,6,7}
[[email protected] tftpboot]# mkdir /var/lib/tftpboot/pxelinux.cfg
[[email protected] tftpboot]# cp /var/www/html/centos/5/isolinux/{vmlinuz,initrd.img} /var/lib/tftpboot/centos5/
[[email protected] tftpboot]# cp /var/www/html/centos/6/isolinux/{vmlinuz,initrd.img} /var/lib/tftpboot/centos6/
[[email protected] tftpboot]# cp /var/www/html/centos/6/isolinux/{vmlinuz,initrd.img} /var/lib/tftpboot/centos7/

9.拷贝pxe需要的配置文件

[[email protected] tftpboot]# cp /usr/share/syslinux/{menu.c32,pxelinux.0} .  #当前目录/var/lib/tftpboot/
[[email protected] tftpboot]# cp /var/www/html/centos/7/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default

10.配置/var/lib/tftpboot/pxelinux.cfg/default文件,作用是让用户选择安装的系统版本

[[email protected] pxelinux.cfg]# cat default
default menu.c32
timeout 600  #不选择默认多少秒进入默认选项
display boot.msg
menu title AutoInstall CentOS 5,6,7
label centos 5 mini
  menu label ^Install CentOS 5
  kernel centos5/vmlinuz
  append initrd=centos5/initrd.img ks=http://192.168.0.254/centos/ksdir/ks5.cfg   #centos5的ks.cfg文件
label centos 6 mini
  menu label I^nstall CentOS 6
  kernel centos6/vmlinuz  #这里的路径是填的以/var/lib/tftpboot为路径的相对路径
  append initrd=centos6/initrd.img ks=http://192.168.0.254/centos/ksdir/ks6.cfg #centos6的ks.cfg文件
label centos 7 mini
  menu label In^stall CentOS 7
  kernel centos7/vmlinuz
  append initrd=centos7/initrd.img ks=http://192.168.0.254/centos/ksdir/ks7.cfg #centos7的ks.cfg文件
label local   #若不选在则默认从硬盘启动
  menu label Boot from ^local drive
  localboot 0xffff
  menu default
menu end

自此实现自动化安装系统

以上是关于利用DHCP,http,tftp,pxe实现纯自动化安装系统的主要内容,如果未能解决你的问题,请参考以下文章

自动化批量部署Linux系统(Kickstart+DHCP+NFS(http)+TFTP+PXE)

Linux系统中Kickstart+HTTP+DHCP+TFTP全自动批量安装部署

基于 cobbler 实现自动安装 linux 系统

PXE通过网络自动化安装系统

kickstart自动化安装--tftp+nfs+dhcp

DHCP+VSFTPD+TFTP+Kickstart搭建PXE环境实现批量自动化系统安装