设为首页 收藏本站
查看: 597|回复: 0

[经验分享] CentOS 6.4下PXE+Kickstart无人值守安装操作系统

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-12-1 08:48:13 | 显示全部楼层 |阅读模式
一、简介
1.1 什么是PXE
PXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统,在启动过程中,终端要求服务器分配IP地址,再用TFTP(trivial file transfer protocol)或MTFTP(multicast trivial file transfer protocol)协议下载一个启动软件包到本机内存中执行,由这个启动软件包完成终端基本软件设置,从而引导预先安装在服务器中的终端操作系统。
严格来说,PXE 并不是一种安装方式,而是一种引导方式。进行 PXE 安装的必要条件是在要安装的计算机中必须包含一个 PXE 支持的网卡(NIC),即网卡中必须要有 PXE Client。PXE 协议可以使计算机通过网络启动。此协议分为 Client端和 Server 端,而PXE Client则在网卡的 ROM 中。当计算机引导时,BIOS 把 PXE Client 调入内存中执行,然后由 PXE Client 将放置在远端的文件通过网络下载到本地运行。运行 PXE 协议需要设置 DHCP 服务器和 TFTP 服务器。DHCP 服务器会给 PXE Client(将要安装系统的主机)分配一个 IP 地址,由于是给 PXE Client 分配 IP 地址,所以在配置 DHCP 服务器时需要增加相应的 PXE 设置。此外,在 PXE Client 的 ROM 中,已经存在了 TFTP Client,那么它就可以通过 TFTP 协议到 TFTP Server 上下载所需的文件了。
PXE的工作过程:
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、FTP、NFS 方式之一进行安装;
详细工作流程,请参考下面这幅图:
152331547498487.jpg
1.2 什么是Kickstart
Kickstart是一种无人值守的安装方式。它的工作原理是在安装过程中记录典型的需要人工干预填写的各种参数,并生成一个名为ks.cfg的文件。如果在安装过程中(不只局限于生成Kickstart安装文件的机器)出现要填写参数的情况,安装程序首先会去查找Kickstart生成的文件,如果找到合适的参数,就采用所找到的参数;如果没有找到合适的参数,便需要安装者手工干预了。所以,如果Kickstart文件涵盖了安装过程中可能出现的所有需要填写的参数,那么安装者完全可以只告诉安装程序从何处取ks.cfg文件,然后就去忙自己的事情。等安装完毕,安装程序会根据ks.cfg中的设置重启系统,并结束安装。
PXE+Kickstart 无人值守安装操作系统完整过程如下:
152331554052088.jpg
二、系统环境
实验环境:VMware Workstation 10
系统平台:CentOS release 6.4 (最小化安装)
网络模式:NAT模式(共享主机的IP地址)
DHCP / TFTP IP:192.168.111.130
HTTP / FTP / NFS IP:192.168.111.130
防火墙已关闭/iptables: Firewall is not running.
SELINUX=disabled
三、准备工作
生成ks.cfg 文件需要system-config-kickstart 工具,而此工具依赖于X Windows,所以我们需要安装X Windows 和Desktop 并重启系统,操作如下:
# yum groupinstall "X Window System"
# yum groupinstall Desktop
# reboot
四、配置HTTP安装方式
系统的安装方式可以选择HTTP、FTP、 NFS,我们这里介绍HTTP方式的安装,其他两种方式的安装,大家可以自行百度。
4.1 安装并配置HTTP
# yum install httpd –y
# rpm -qa|grep httpd
152331560306445.jpg
开启服务并设置开机启动
# /etc/init.d/httpd start
# chkconfig --level 35 httpd on
4.2 加载ISO镜像
在虚拟机中设置加载ISO镜像。
152331566869046.jpg
将iso文件挂载至/mnt/cdrom.
152331572179674.jpg
4.3 复制光盘全部内容至http 的根目录/var/www/html/ 下
# cp -r /mnt/cdrom/ /var/www/html/
HTTP部分设置完毕。
五、配置TFTP
5.1 安装tftp-server
# yum install tftp-server –y
5.2 启用tftp 服务
# vi /etc/xinetd.d/tftp
service tftp
{
        socket_type             = dgram
        protocol                = udp
        wait                    = yes
        user                    = root
        server                  = /usr/sbin/in.tftpd
        server_args             = -s /var/lib/tftpboot
        disable                 = no
        per_source              = 11
        cps                     = 100 2
        flags                   = IPv4 }
将disable 设置为no
5.3 启动tftp服务
因为tftp服务是挂载在超级进程xinetd 下的,所以通过启动xinetd 来启动tftp服务。
# /etc/init.d/xinetd restart
152331576703746.jpg
设置开机启动xinetd
# chkconfig xinetd on
六、配置支持PXE的启动程序
6.1 复制pxelinux.0 文件至/var/lib/tftpboot/ 文件夹中
# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
说明:syslinux是一个功能强大的引导加载程序,而且兼容各种介质。更加确切地说:SYSLINUX是一个小型的Linux操作系统,它的目的是简化首次安装Linux的时间,并建立修护或其它特殊用途的启动盘。
6.2 复制iso 镜像中的/image/pxeboot/initrd.img 和vmlinux 至/var/lib/tftpboot/ 文件夹中
# cp /var/www/html/cdrom/images/pxeboot/{initrd.img,vmlinuz} /var/lib/tftpboot/
6.3 复制iso 镜像中的/isolinux/*.msg 至/var/lib/tftpboot/ 文件夹中
# cp /var/www/html/cdrom/isolinux/*.msg /var/lib/tftpboot/
6.4 在/var/lib/tftpboot/ 中新建一个pxelinux.cfg目录
# mkdir /var/lib/tftpboot/pxelinux.cfg
6.5 将iso 镜像中的/isolinux 目录中的isolinux.cfg复制到pxelinux.cfg目录中,同时更改文件名称为default
# cp /var/www/html/cdrom/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
6.6 修改default文件
# vi /var/lib/tftpboot/pxelinux.cfg/default


default ks     #默认启动的是 'label ks' 中标记的启动内核prompt 1          #显示 'boot: ' 提示符。为 '0' 时则不提示,将会直接启动 'default' 参数中指定的内容。timeout 6      #在用户输入之前的超时时间,单位为 1/10 秒。display boot.msg  #显示某个文件的内容,注意文件的路径。默认是在/var/lib/tftpboot/ 目录下。也可以指定位类似 '/install/boot.msg'这样的,路径+文件名。F1 boot.msg     #按下 'F1' 这样的键后显示的文件。F2 options.msg
F3 general.msg
F4 param.msg
F5 rescue.msg
label linux       #'label' 指定你在 'boot:' 提示符下输入的关键字,比如boot: linux[ENTER],这个会启动'label linux' 下标记的kernel 和initrd.img 文件。
  kernel vmlinuz  #kernel 参数指定要启动的内核。
  append initrd=initrd.img #append 指定追加给内核的参数,能够在grub 里使用的追加给内核的参数,在这里也都可以使用。label text
  kernel vmlinuz
  append initrd=initrd.img text
label ks
  kernel vmlinuz
  append ks=http://192.168.111.130/ks.cfg initrd=initrd.img    #告诉系统,从哪里获取ks.cfg文件 label local
  localboot 1 label memtest86
  kernel memtest
  append -

七、配置DHCP
7.1 安装DHCP服务
# yum -y install dhcp
7.2 复制配置模板文件到DHCP的配置目录中
# cp -f /usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample  /etc/dhcp/dhcpd.conf
7.3 修改/etc/dhcp/dhcpd.conf 配置文件,内容如下:


ddns-update-style interim;
ignore client-updates;
filename "pxelinux.0";   #pxelinux 启动文件位置;next-server 192.168.111.130;  #TFTP Server 的IP地址;subnet 192.168.111.0 netmask 255.255.255.0 {

        option routers                  192.168.111.130;
        option subnet-mask              255.255.255.0;

        range dynamic-bootp 192.168.111.100 192.168.111.200;
        default-lease-time 21600;
        max-lease-time 43200;
}


7.4 启动DHCP服务
# /etc/init.d/dhcpd start
152331582175846.jpg
八、生成ks.cfg 文件
8.1 安装Kickstart
# yum install system-config-kickstart
8.2 在桌面环境下配置Kickstart
启动X Windows 环境
# startx
配置Kickstart
# system-config-kickstart
A. 设置语言,键盘,时区,Root密码,安装完毕后重启等。
152331591707004.jpg
B. 设置安装方式,这篇文章介绍的是HTTP方式的安装,故选择HTTP
181628036291619.jpg
C. 安装MBR
152332006393019.jpg
D. 设置分区
152332015303393.jpg
E. 分区总览
152332025929349.jpg
F. 配置网络
152332033749221.jpg
G. 认证配置
152332040611067.jpg
H. SELinux 和防火墙配置
152332047642980.jpg
I. 图形环境配置
152332053897337.jpg
J. 软件包安装选择
152332063115953.jpg
K. 预览
152332076089682.jpg
L. 生成ks.cfg 文件,保存在/var/www/html/ 文件夹下
152332083894854.jpg
我们可以打开/var/www/html/ks.cfg 文件进行查看并做修改。

platform=x86, AMD64, or Intel EM64T
#version=DEVEL
# Firewall configuration
firewall --disabled
# Install OS instead of upgrade
install
# Use network installation
url --url=http://192.168.111.130/cdrom/   #这个选项告诉安装程序:到服务器192.168.111.130 的HTTP根目录下的cdrom 文件夹下寻找安装介质# Root password
rootpw --iscrypted $1$vsvtP./e$6PVMNfJd.shq2LgFJjYfA1
# System authorization information
auth  --useshadow  --enablemd5
# Use graphical install
graphical
firstboot --disable
# System keyboard
keyboard us
# System language
lang en_US
# SELinux configuration
selinux --disabled
# Installation logging level
logging --level=info
# Reboot after installation
reboot # System timezone
timezone  --isUtc Asia/Shanghai
# Network information
network  --bootproto=dhcp --device=eth0 --onboot=on
# System bootloader configuration
key --skip bootloader --append="rhgb quiet" --location=mbr --driveorder=sda
# Clear the Master Boot Record
zerombr
# Partition clearing information
clearpart --all --initlabel # Disk partitioning information
part / --fstype="ext4" --size=8192
part swap --fstype="swap" --size=1024
part /home --fstype="ext4" --size=2048

%packages
@base

%end


说明:key --skip 如果是红帽系统,此选项可以跳过输入序列号过程;如果是CentOS 系列,则可以不保留此项内容;
reboot 此选项必须存在,也必须文中设定位置,不然kickstart显示一条消息,并等待用户按任意键后才重新引导;
clearpart --all --initlabel 此条命令必须添加,不然系统会让用户手动选择是否清除所有数据,这就需要人为干预了,从而导致自动化过程失败;
九、测试安装
自动化安装系统配置完毕,下面启动一台新的机器进行测试,网络连接模式选择NAT模式。
152332091557955.jpg
新建虚拟机,选择自定义(高级)
152332097959083.jpg
选择“稍后安装操作系统”
152332134994215.jpg
选择客户机操作系统类型
152332140617788.jpg
命名虚拟机
152332146554902.jpg
设置此虚拟机的内存
152332152492017.jpg
设置网络类型
152332159836875.jpg
选择I/O控制器类型
152332169833047.jpg
选择磁盘类型
152332176244175.jpg
选择磁盘
152332182806776.jpg
指定磁盘大小,ks.cfg 文件中,我们定义了/ 大小为8GB,swap 分区为1GB,/home 分区为2GB,所以这里的磁盘大小至少要为12GB。
而且,一定要勾选上“立即分配所有磁盘空间”,不然在后来安装的时候将提示没有磁盘空间。
152332189834391.jpg
指定磁盘文件
152332196245520.jpg
虚拟机总览
152332202172634.jpg
正在创建磁盘,过程会很慢,虚拟机需要产生一个20GB的文件。
152332207179720.jpg
启动虚拟机,选择从网卡启动,DHCP 服务器正在给客户机分配IP地址。
152332213278307.jpg
开始下载vmlinuz 和initrd.img
152332218741408.jpg
安装过程...
152332224056736.jpg
安装过程...
152332229837080.jpg
安装过程...
152332238424508.jpg
安装完毕,重启后,显示登录界面
152332247647423.jpg
登录系统查看,磁盘分区和我们在ks.cfg 文件中设定的一样。
152332255922310.jpg



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-145642-1-1.html 上篇帖子: Linux报错warning: the home directory already exists. 下篇帖子: CentOS 6.5 VNC 安装 操作系统
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表