PXE+kickstart网络安装CentOS7.4系统及过程中各种报错

时间:2022-04-24
本文章向大家介绍PXE+kickstart网络安装CentOS7.4系统及过程中各种报错,主要内容包括kickstart的原理及组件、首先安装DHCP、启动dhcp查看日志、dhcp相关错误须知、然后安装TFTP、tftp相关错误须知、安装syslinux,生成/pxelinux.0文件、然后进行镜像挂载、安装http、编辑default配置文件、自动安装(编写ks文件)、包组段、脚本段、低级错误、CentOS7.4网络安装、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

环境:关闭防火墙、selinux

注意:虚拟机进行网络安装的话,7.3以后的系统是需要2G以上的内存

[root@kickstart ~]# cat /etc/redhat-release
CentOS Linux release 7.4.1708 (Core)
[root@kickstart ~]# uname -r
3.10.0-693.el7.x86_64
[root@kickstart ~]# getenforce
Disabled
[root@kickstart ~]# systemctl status  firewalld.service
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
   Active: inactive (dead)
     Docs: man:firewalld(1)
[root@kickstart ~]# hostname -I
10.0.0.201 172.16.1.201

博主使用的是虚拟机搭建

此篇博主在搭建中的每一步都列出了会出现的错误和解决方式,如果出错了,不要着急,耐心看。

有错、排错是提升的最快方式。

kickstart的原理及组件

首先安装DHCP

yum install dhcp -y

配置DHCP配置文件

cat >>/etc/dhcp/dhcpd.conf<<EOF
subnet 172.16.1.0 netmask 255.255.255.0 {   ## 指定网段   
range 172.16.1.100 172.16.1.199;     ## 地址范围   
option subnet-mask 255.255.255.0;   ## 分配的掩码 
default-lease-time 21600;   ## 地址租约   
max-lease-time 43200;       ## 最大租约   
next-server 172.16.1.201;   ## 下一步找什么  
filename "/pxelinux.0";    ## 要下载的文件(请求下载启动文件)
}
EOF

启动dhcp查看日志

systemctl start dhcpd     --- 启动
systemctl status dhcpd    --- 查看状态
tailf /var/log/messages   --- 查看日志

dhcp相关错误须知

然后安装TFTP

yum install tftp-server -y

启动服务

[root@kickstart ~]# systemctl start tftp.socket 
[root@kickstart ~]# systemctl status tftp.socket 
● tftp.socket - Tftp Server Activation Socket
   Loaded: loaded (/usr/lib/systemd/system/tftp.socket; disabled; vendor preset: disabled)
   Active: active (listening) since 二 2017-11-14 10:09:55 CST; 25s ago
   Listen: [::]:69 (Datagram)

11月 14 10:09:55 kickstart systemd[1]: Listening on Tftp Server Activation ...t.
11月 14 10:09:55 kickstart systemd[1]: Starting Tftp Server Activation Socket.
Hint: Some lines were ellipsized, use -l to show in full.

tftp相关错误须知

报错是在TFTP服务的根目录找不到启动文件pxelinux.0

解决:下载安装syslinux

安装syslinux,生成/pxelinux.0文件

[root@kickstart tftpboot]# yum install syslinux -y
[root@kickstart tftpboot]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
[root@kickstart tftpboot]# ll
总用量 28
-rw-r--r-- 1 root root 26764 11月 14 10:16 pxelinux.0

错误须知

首先排除最简单故障原因:selinux是否关闭,防火墙是否关闭

上面的错误是因为pxelinux.0这个小系统的配置文件(default)不存在,或者文件名不对

 然后进行镜像挂载

检查一下虚拟机是否使用了镜像

然后进行挂载

[root@kickstart tftpboot]# mkdir -p /var/www/html/CentOS7
[root@kickstart tftpboot]# mount /dev/cdrom /var/www/html/CentOS7/
mount: /dev/sr0 写保护,将以只读方式挂载
[root@kickstart tftpboot]# df -h
文件系统        容量  已用  可用 已用% 挂载点
/dev/sda3        98G  1.5G   97G    2% /
devtmpfs        479M     0  479M    0% /dev
tmpfs           489M     0  489M    0% /dev/shm
tmpfs           489M  6.8M  482M    2% /run
tmpfs           489M     0  489M    0% /sys/fs/cgroup
/dev/sda1      1014M  120M  895M   12% /boot
tmpfs            98M     0   98M    0% /run/user/0
/dev/sr0        4.3G  4.3G     0  100% /var/www/html/CentOS7

从镜像中找到相关的配置文件

[root@kickstart tftpboot]# cp -a /var/www/html/CentOS7/isolinux/* /var/lib/tftpboot/
[root@kickstart tftpboot]# mkdir -p /var/lib/tftpboot/pxelinux.cfg 
[root@kickstart tftpboot]# cp /var/www/html/CentOS7/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default

安装http

     作用1:提供自动应答文件下载

     作用2:提供安装系统所需的所有rpm包下载

下载安装
[root@kickstart tftpboot]# yum install httpd -y
启动服务
[root@kickstart tftpboot]# systemctl start httpd.service
检测
[root@kickstart tftpboot]# curl http://172.16.1.201/CentOS7/

编辑default配置文件

[root@kickstart ks_config]# cat /var/lib/tftpboot/pxelinux.cfg/default 
default ks
prompt 0
label ks
  kernel vmlinuz
  append initrd=initrd.img ks=http://172.16.1.201/ks_config/CentOS7-ks.cfg net.ifnames=0 biosdevname=0 ksdevice=eth1

自动安装(编写ks文件)

命令段

    install开头,到%pre

包组段

    以%packages开头,以%end结束

脚本段

    以%post开头,以%end结束,在安装完系统之后执行的相关Linux命令、脚本

    以%pre开头,以%end结束,在安装完系统之前执行的相关Linux命令、脚本

[root@kickstart ks_config]# cat CentOS7-ks.cfg 
# Kickstart Configurator for CentOS 7 by yao zhang
install               ## 告知这是一次安装程序
url --url=http://172.16.1.201/CentOS7/     ## 通过ftp或http从远程服务器安装的地址
text                 ## 使用文本模式安装
lang en_US.UTF-8        ## 设置安装过程中使用的语言字符集
keyboard us       ## 设置系统键盘类型为us
zerombr            ## 清除mbr引导信息
bootloader --location=mbr --driveorder=sda --append="crashkernel=auto rhgb quiet"        --location=mbr  ## 指定引导记录被写入的位置  
                --driveorder=sda     ## 指定在BIOS引导顺序中居首的驱动器
--append="crashkernel=auto rhgb quiet"  ## 指定内核参数,要指定多个参数空格分隔,为通过网络的kickstart安装以及所安装的系统配置联网信息。
network  --bootproto=static --device=eth0 --gateway=10.0.0.254 --ip=10.0.0.202 --nameserver=223.5.5.5 --netmask=255.255.255.0 --activate
network  --bootproto=static --device=eth1 --ip=172.16.1.202 --netmask=255.255.255.0 --activate
network  --hostname=Cobbler      ## 以上是静态配置ip网络信息的写法
#network --bootproto=dhcp --device=eth1 --onboot=yes --noipv6 --hostname=CentOS7    ## 动态配置ip网络信息的写法和配置主机名
timezone --utc Asia/Shanghai        ## 设置时区为亚洲上海
authconfig --enableshadow --passalgo=sha512          ## 系统认证信息,这里要是写密文密码需加  设置密码加密方式为sha512 启用shadow文件
rootpw  --iscrypted $6$X20eRtuZhkHznTb4$dK0BJByOSAWSDD8jccLVFz0CscijS9ldMWwpoCw/ZEjYw2BTQYGWlgKsn945fFTjRC658UXjuocwJbAjVI5D6/    ## 加密的root密码
clearpart --all --initlabel          ## 清空分区,清空所有分区
part /boot --fstype xfs --size 1024   ## 为分区设置文件系统类型为xfs,size设置大小
part swap --size 1024    
part / --fstype xfs --size 1 --grow   ## grow把剩余容量都给这个分区
firstboot --disable        ## 协助配置服务器的重要信息
selinux --disabled         ## 关闭selinux
firewall --disabled        ## 关闭防火墙
logging --level=info       ## 设置日志级别
reboot        ## 设置安装完成后重启,必须存在

%packages            ## 这一部分是要安装的一些包
@^minimal
@compat-libraries
@debugging
@development
tree
nmap
sysstat
lrzsz
dos2unix
telnet 
wget 
vim 
bash-completion
%end

%post            ## 安装后执行的命令,如果要一键化搭建集群,这里可以执行写好的shell或ansible剧本进行搭建
systemctl disable postfix.service
%end

低级错误

报错原因:selinux没关

解决:关闭selinux

CentOS7.4网络安装

 安装过程的常见报错

原因:CentOS6和7的default文件中的append这一行不同

解决方法:改append这一行

欢迎大家私信,不足之处请指出。