0
点赞
收藏
分享

微信扫一扫

PEX无人值守环境安装脚本

小迁不秃头 2022-04-15 阅读 58
linux

 操作可查阅之前的文章,这里主要是shell脚本

#!/bin/bash
#关闭防火墙,selinux
service iptables stop &>/dev/null
setenforce 0 &>/dev/null
#获得当前主机的IP地址
IP=$(ifconfig | head -2 | grep "inet addr" | awk  '{print $2}'|awk -F: '{print $2}')
#获得当前主机的网络号
NETIP=$(echo $IP |awk -F. '{print $1"."$2"."$3}')
#获得当前主机的子网掩码
MASK=$(ifconfig |head -2 | tail -1 |awk '{print $4}'|awk -F: '{print $2}')
#挂载
mount /dev/sr0 /mnt &>/dev/null
n=$(ls /mnt/$Date |wc -l)
if [ $n -eq 0 ]
then
  echo "没有挂载光盘,请挂载光盘,退出脚本执行状态!"
  exit
fi
#配置本地yum仓库
rm -fr /etc/yum.repos.d/*
cat >>/etc/yum.repos.d/base.repo<<OK
[baseos]
name=baseos
baseurl=/mnt/BaseOS
gpgcheck=0
[appstream]
name=appsTream
baseurl=/mnt/AppStream
gpgcheck=0
OK
dnf clean all &>/dev/null

#搭建ftp站点
if [ -d /etc/vsftpd ]
then
  #把光盘文件复制到ftp站点下
  mkdir /var/ftp/redhat6
  echo "正在复制光盘文件........"
  cp -rf /mnt/* /var/ftp/redhat6
  echo "完成复制......."
  #启动ftp服务
  service vsftpd restart &>/dev/null
else
  echo "该系统没有安装ftp服务,正在安装,请稍等....."
 dnf install vsftpd -y &>/dev/null
  if [ ! -d /etc/vsftpd ]
  then
    echo "安装ftp失败,退出脚本执行状态!"
    exit
  fi
  #把光盘文件复制到ftp站点下
  mkdir /var/ftp/redhat6
  echo "正在复制光盘文件........"
  cp -rf /mnt/* /var/ftp/redhat6
  echo "完成复制......."
  #启动ftp服务
  service vsftpd start &>/dev/null
fi
#搭建tftp站点
if [ -f /etc/xinetd.d/tftp ]
then
  #修改tftp配置文件,tftp默认是禁用,开启tftp功能
  tftp_status=$(grep disable /etc/xinetd.d/tftp |awk -F= '{print $2}')
  sed -i "s/$tftp_status/no/" /etc/xinetd.d/tftp
  #启动tftp服务
  service xinetd restart &>/dev/null
else
  echo "该系统没有安装tftp服务,正在安装,请稍等....."
  dnf install tftp-server -y &>/dev/null
  if [ ! -f /etc/xinetd.d/tftp ]
  then
    cat >>/etc/xinetd.d/tftp<<OK
      service tftp
      {
      disable          =yes
      socket_type      = dgram
      protocol         = udp
      wait             = yes
      user             = root
      server           = /usr/sbin/in.tftpd
      server_args      = -s /tftpboot -c
      per_source       = 11
      cps              = 100 2
      flags            = IPv4
      }
OK
  fi
  #修改tftp配置文件,tftp默认是禁用,开启tftp功能
  tftp_status=$(grep disable /etc/xinetd.d/tftp |awk -F= '{print $2}')
  sed -i "s/$tftp_status/no/" /etc/xinetd.d/tftp
  #启动tftp服务
  
service xinetd start &>/dev/null
fi
#部署客户端主机无盘启动时所需的Linux内核、初始化镜像文件
cd /mnt/images/pxeboot
cp vmlinuz initrd.img  /var/lib/tftpboot
#准备客户端主机无盘启动时所需的PXE引导程序(pxelinux.0)、启动菜单文件
#安装syslinux软件包(支持PXE功能)
dnf install syslinux -y &>/dev/null
if [ ! -d /usr/share/syslinux ]
then
    echo "没有安装成功syslinux,退出脚本执行状态!"
    exit
fi
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot
#建立启动菜单文件
mkdir /var/lib/tftpboot/pxelinux.cfg
cat >>/var/lib/tftpboot/pxelinux.cfg/default<<OK
default auto
prompt  0
label   auto
kernel  vmlinuz
         append ks=ftp://$IP/redhat6/ks.cfg  initrd=initrd.img devfs=nomount ramdisk_size=8192
label   linux text
         kernel  vmlinuz
         append text initrd=initrd.img devfs=nomount ramdisk_size=8192
label    linux     rescue
kernel    vmlinuz
append    rescue     initrd=initrd.img devfs=nomount ramdisk_size=8192
OK
#修改default文件权限
chmod 777 /var/lib/tftpboot/pxelinux.cfg/default
#配置DHCP服务
if [ -f /etc/dhcp/dhcpd.conf ]
then
cat >/etc/dhcp/dhcpd.conf<<OK
subnet $NETIP.0 netmask $MASK {
  range $NETIP.50 $NETIP.100;
  option domain-name-servers ns1.internal.example.org;
  option domain-name "internal.example.org";
  option routers $IP;
  default-lease-time 600;
  max-lease-time 7200;
  next-server $IP;
  filename "pxelinux.0";
}
OK
#启动dhcp服务
systemctl restart dhcpd &>/dev/null
else
  echo "该系统没有安装dhcp服务,正在安装,请稍等....."
  dnf install dhcp-server -y &>/dev/null
  if [ ! -f /etc/dhcp/dhcpd.conf ]
  then
    echo "安装dhcp失败,退出脚本执行状态!"
    exit
  fi
  cat >/etc/dhcp/dhcpd.conf<<OK
subnet $NETIP.0 netmask $MASK {
  range $NETIP.50 $NETIP.100;
  option domain-name-servers ns1.internal.example.org;
  option domain-name "internal.example.org";
  option routers $IP;
  default-lease-time 600;
  max-lease-time 7200;
  next-server $IP;
  filename "pxelinux.0";
}
OK
#启动dhcp服务
systemctl restart dhcpd &>/dev/null
fi
#配置实现客户端无人值守安装系统
#安装system-config-kickstart软件包
echo "正在安装system-config-kickstart软件包"
dnf -y install system-config-kickstart &>/dev/null
echo "安装system-config-kickstart软件包完成!"
#配置ks.cfg文件
cat  >/var/ftp/redhat6/ks.cfg<<OK
#platform=x86, AMD64, 或 Intel EM64T
#version=DEVEL
# Firewall configuration
firewall --disabled
# Install OS instead of upgrade
install
# Use network installation
url --url="ftp://$IP/redhat6"
# Root password
rootpw --iscrypted $1$EdNye4v8$k9lKFbLL44WbEYorBFU/S1
# System authorization information
auth  --useshadow  --passalgo=sha512
# Use graphical install
graphical
firstboot --disable
# System keyboard
keyboard us
# System language
lang zh_CN
# SELinux configuration
selinux --enforcing
# Installation logging level
logging --level=info
OK
echo "pxe服务端部署完成!"
举报

相关推荐

0 条评论