欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

cent7中kickstart初步探究

程序员文章站 2022-12-10 13:27:56
一、基本环境 操作系统:CentOS7.4 内核版本:3.10.0-862.11.6.el7.x86_64 二、组件部署 yum安装tftp tftpd-server xinetd http dhcp. 安装完成后进行简单必要的配置: 1. tftp守护进程xinetd配置 2. dhcp配置 vi ......

一、基本环境 操作系统: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/

cent7中kickstart初步探究

如上图,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吧!