最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

09/17 07:58
阅读数 30

kickstart

在我们日常工作中难免会出现一些系统安装的过程,但是有时候安装任务会很多,比如几十台,几百台机器,人工手动安装会有点难受,这里给大家提供一个kick start,我们可以通过手动配置来自动安装系统,这时对于部署大量机器,显得尤为重要,下面来介绍下kick start,如何安装,

官方给的一些说明,大家可以参考.
https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/8/html/performing_an_advanced_rhel_installation/index
https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/installation_guide/sect-kickstart-syntax
https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/6/html/installation_guide/s1-kickstart2-options


kickstart文件主要包括三个部分:命令段,程序包段,脚本段

  • 命令段:指明各种安装前配置,如键盘类型等
    命令段中的常见命令:
    keyboard: 设定键盘类型
    lang: 语言类型
    zerombr:清除mbr
    clearpart:清除分区
    part: 创建分区
    rootpw: 指明root的密码
    timezone: 时区
    text: 文本安装界面
    network:指定网络设置
    firewall:设置防火墙设置
    selinux:设置selinux设置
    reboot:安装完自动重启
    user:安装完成后为系统创建新用户
    url: 指明安装源














  • 程序包段:指明要安装的程序包组或程序包,不安装的程序包等
    %packages
    @^environment group: 指定环境包组,如:@^minimal-environmentbr/>@group_name
    package
    -package
    %end




  • 脚本段:
    %pre: 安装前脚本
    %post: 安装后脚本

这里要注意:

CentOS 8,7,6 不同版本的kickstart文件格式不尽相同,不可混用
%addon, %packages, %onerror, %pre 、 %post 必须以%end结束,否则安装失败

以下为centos 8.的最小安装kiskstart文件配置


ignoredisk --only-use=sda               #此行必须指定
zerombr                               #grub清空   
text
reboot
clearpart --all --initlabel
selinux --disabled #禁用SELinux
firewall --disabled #禁用firewalld
url --url=http://10.0.0.8/centos/8/os/x86_64/ 
keyboard --vckeymap=us --xlayouts='us'
lang en_US.UTF-8
bootloader --append="net.ifnames=0" --location=mbr --boot-drive=sda  #此行必须指定
network  --bootproto=dhcp --device=eth0 --ipv6=auto --activate
network  --hostname=centos8.magedu.org
rootpw --iscrypted
$6$j9YhzDUnQVnxaAk8$qv7rkMcPAEbV5yvwsP666DXWYadd3jYjkA9fpxAo9qYotjGGBUclCGoP1TRv
gHBpqgc5n0RypMsPTQnVDcpO01
firstboot --enable
skipx
services --disabled="chronyd"
timezone Asia/Shanghai --isUtc --nontp
user --name=wang --
password=6oUfb/02CWfLb5l8f$sgEZeR7c7DpqfpmFDH6huSmDbW1XQNR4qKl2EPns.gOXqlnAIgv9p
TogtFVaDtEpMOC.SWXKYqxfVtd9MCwxb1 --iscrypted --gecos="wang"
#autopart --type=lvm            #自动按照逻辑卷分区

#part / --fstype xfs --size 1 --grow --ondisk sda 可以实现根自动使用所有剩余空间
part / --fstype="xfs" --ondisk=sda --size=102400
part /data --fstype="xfs" --ondisk=sda --size=51200
part swap --fstype="swap" --ondisk=sda --size=2048
part /boot --fstype="ext4" --ondisk=sda --size=1024
%packages
@^minimal-environment
kexec-tools
vim
curl
wget
tree
%end
%addon com_redhat_kdump --enable --reserve-mb='auto'
%end
%anaconda
pwpolicy root --minlen=6 --minquality=1 --notstrict --nochanges --notempty
pwpolicy user --minlen=6 --minquality=1 --notstrict --nochanges --emptyok
pwpolicy luks --minlen=6 --minquality=1 --notstrict --nochanges --notempty
%end
%post
useradd mage
echo magedu | passwd --stdin mage &> /dev/null
%end

  1 ignoredisk --only-use=sda
  2 zerombr
  3 text
  4 reboot
  5 clearpart --all --initlabel
  6 selinux --disabled
  7 firewall --disabled
  8 url --url=http://10.0.0.80/centos/8/os/x86_64/
  9 keyboard --vckeymap=us --xlayouts='us'
 10 lang en_US.UTF-8
 11 network  --bootproto=dhcp --device=ens160 --ipv6=auto --activate
 12 network  --hostname=centos8.magedu.com
 13 rootpw --iscrypted $6$j9YhzDUnQVnxaAk8$qv7rkMcPAEbV5yvwsP666DXWYadd3jYjkA9fpxAo9qYotjGGBUclCGoP1TRvgHBpqgc5n0Ry    pMsPTQnVDcpO01
 14 firstboot --enable
 15 skipx
 16 services --disabled="chronyd"
 17 timezone Asia/Shanghai --isUtc --nontp
 18 user --name=rzx --password=6oUfb/02CWfLb5l8f$sgEZeR7c7DpqfpmFDH6huSmDbW1XQNR4qKl2EPns.gOXqlnAIgv9pTogtFVaDtEpMO    C.SWXKYqxfVtd9MCwxb1 --iscrypted --gecos="wang"
 19 part / --fstype="xfs" --ondisk=sda --size=102400
 20 part /data --fstype="xfs" --ondisk=sda --size=51200
 21 part swap --fstype="swap" --ondisk=sda --size=2048
 22 part /boot --fstype="ext4" --ondisk=sda --size=1024
 23 %packages
 24 @^minimal-environment
 25 kexec-tools
 26 %end
 27 %addon com_redhat_kdump --enable --reserve-mb='auto'
 28 %end
 29 %anaconda
 30 pwpolicy root --minlen=6 --minquality=1 --notstrict --nochanges --notempty
 31 pwpolicy user --minlen=6 --minquality=1 --notstrict --nochanges --emptyok
 32 pwpolicy luks --minlen=6 --minquality=1 --notstrict --nochanges --notempty
 33 %end
 34
 35 %post
 36 useradd mage
 37 echo magedu | passwd --stdin mage &> /dev/null
 38 %end

CentOS 7 的最小化安装kickstart文件

install
xconfig  --startxonboot
keyboard --vckeymap=us --xlayouts='us'
rootpw --iscrypted $1$bpNEv8S5$lK.CjNkf.YCpFPHskSNiN0
url --url="http://10.0.0.8/centos/7/os/x86_64"
lang en_US
auth  --useshadow  --passalgo=sha512
text
firstboot --enable
selinux --disabled
skipx
services --disabled="chronyd"
ignoredisk --only-use=sda
firewall --disabled
network  --bootproto=dhcp --device=ens33
reboot
timezone Asia/Shanghai --nontp
bootloader --append="crashkernel=auto" --location=mbr --boot-drive=sda
zerombr
clearpart --all --initlabel
part swap --fstype="swap" --ondisk=sda --size=3072
part / --fstype="xfs" --ondisk=sda --size=51200
part /boot --fstype="xfs" --ondisk=sda --size=1024
part /data --fstype="xfs" --ondisk=sda --size=30720
%post
useradd wang
%end
%packages
@^minimal
vim-enhanced
%end

  1 #platform=x86, AMD64, or Intel EM64T
  2 #version=DEVEL
  3 # Install OS instead of upgrade
  4 install
  5 # Keyboard layouts
  6 keyboard 'us'
  7 # Root password
  8 rootpw --plaintext magedu
  9 # System language
 10 lang en_US
 11 # System authorization information
 12 auth  --useshadow  --passalgo=sha512
 13 # Use text mode install
 14 text
 15 firstboot --disable
 16 # SELinux configuration
 17 selinux --disabled
 18
 19
 20 # Firewall configuration
 21 firewall --disabled
 22 # Network information
 23 network  --bootproto=static --device=eth0 --ip=10.0.0.123 --netmask=255.255.255.0
 24 # Reboot after installation
 25 reboot
 26 # System timezone
 27 timezone Asia/Shanghai
 28 # Use network installation
 29 url --url="http://10.0.0.8/centos/7/os/x86_64"
 30 # System bootloader configuration
 31 bootloader --append="net.ifnames=0" --location=mbr
 32 # Partition clearing information
 33 clearpart --all
 34 # Disk partitioning information
 35 part / --fstype="xfs" --size=100000
 36
 37 %post
 38 useradd rzx
 39 echo magedu |passwd --stdin 123456
 40 mkdir /etc/yum.repos.d/backup
 41 mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/backup
 42 cat > /etc/yum.repos.d/base.repo <<EOF
 43 [base]
 44 baseurl=http://mirrors.aliyun.com/centos/$releasever/os/$basearch/
 45         http://mirrors.aliyuncs.com/centos/$releasever/os/$basearch/
 46         http://mirrors.cloud.aliyuncs.com/centos/$releasever/os/$basearch/
 47 gpgcheck=1
 48 gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7
 49 EOF
 50 mkdir /root/.ssh -m 700
 51 cat > /root/.ssh/authorized_keys <<EOF
 52 ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAIEAsGcrlhZQUX07tc/F7OEcpUpSYFRP9M+jejHewX8C37aZxxMZLH8ULSrdH8YDbYhyl2/aN7QlxpJ    BxFTEI5CmzLocwRRNVynL4jVRNRa+61Km2CaaqgIio6Kfp7qHqYxZjirY8fDsB8ygjQmF3D5CCCwGd+Y9KxOVNLMdyoQmmK8=
 53 EOF
 54 chmod 600 /root/.ssh/authorized_keys
 55 %end
 56
 57 %packages


CentOS 6 的最小化安装kickstart文件

install
text
reboot
url --url=http://10.0.0.8/centos/6/os/x86_64/
lang en_US.UTF-8
keyboard us
network --onboot yes --device eth0 --bootproto dhcp  --noipv6
rootpw  --iscrypted
$6$b6C5mM/BwOMBoK8H$cYZFrHoNlOL0iDsxOTRhwnWJ3yfFmf7mRJBOxEqGoI56UMrT8J7qlrGwX7tS
nOf7wKxYR2hAvAREILDgOgsFe1
firewall --disabled
authconfig --enableshadow --passalgo=sha512
selinux --disabled
timezone Asia/Shanghai
bootloader --location=mbr --driveorder=sda --append="crashkernel=auto rhgb
quiet"
zerombr
clearpart --all --initlabel
part /boot --fstype=ext4 --size=1024
part / --fstype=ext4 --size=50000
part /data --fstype=ext4 --size=30000
part swap --size=2048

%packages
@core
@server-policy
@workstation-policy
autofs
vim-enhanced
%end
%post
useradd wang
echo magedu | passwd --stdin wang &> /dev/null
mkdir /etc/yum.repos.d/bak
mv /etc/yum.repos.d/* /etc/yum.repos.d/bak
cat > /etc/yum.repos.d/base.repo <<EOF
[base]
name=base
baseurl=file:///misc/cd
gpgcheck=0
EOF
%end

 1 install
  2 text
  3 reboot
  4 url --url=http://10.0.0.80/centos/6/os/x86_64/
  5 lang en_US.UTF-8
  6 keyboard us
  7 network --onboot yes --device eth0 --bootproto dhcp  --noipv6
  8 rootpw  --iscrypted $6$j9YhzDUnQVnxaAk8$qv7rkMcPAEbV5yvwsP666DXWYadd3jYjkA9fpxAo9qYotjGGBUclCGoP1TRvgHBpqgc5n0R    ypMsPTQnVDcpO01
  9 firewall --disabled
 10 authconfig --enableshadow --passalgo=sha512
 11 selinux --disabled
 12 timezone Asia/Shanghai
 13 bootloader --location=mbr --driveorder=sda --append="crashkernel=auto rhgb quiet"
 14 zerombr
 15 clearpart --all --initlabel
 16 part /boot --fstype=ext4 --size=1024
 17 part / --fstype=ext4 --size=50000
 18 part /data --fstype=ext4 --size=30000
 19 part swap --size=2048
 20 %packages
 21 @core
 22 @server-policy
 23 @workstation-policy
 24 autofs
 25 vim-enhanced
 26 %end
 27 %post
 28 useradd wang
 29 echo magedu | passwd --stdin wang &> /dev/null
 30 mkdir  /etc/yum.repos.d/bak
 31 mv /etc/yum.repos.d/* /etc/yum.repos.d/bak
 32 cat > /etc/yum.repos.d/base.repo <<EOF
 33 [base]
 34 name=base
 35 baseurl=file:///misc/cd
 36 gpgcheck=0
 37 EOF
 38 %end

创建kickstart文件的方式

可使用创建工具:system-config-kickstart ,注意:此方法 CentOS 8 不再支持

依据某模板修改并生成新配置,CentOS安装完后,会自动参考当前系统的安装过程,生成一个
kickstart文件 /root/anaconda-ks.cfg

检查ks文件的语法错误:

使用 ksvalidator 工具可以检查kickstart的文件格式是否有语法错误,来自于 pykickstart 包
格式:

ksvalidator /PATH/TO/KICKSTART_FILE

使用之前需要安装kickstart

root@centos7 ~]#yum -y install system-config-kickstart
#  然后让 Xmanager -Passive  运行起来
[21:59:04 root@centos7 ~]#export DISPLAY=10.0.0.1:0.0
[22:09:08 root@centos7 ~]#system-config-kickstart

以下为详细使用使用 system-config-kickstart 生成kickstart`配置文件;

  1. Basic Configuration
    最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

配置文件如下

┌────────────────────────────────────────────────────────┐
│#Basic Configuration            
│========================================================
│#platform=x86, AMD64, or Intel EM64T          
│#Default Language默认语言                
│lang en_US                       
│# Keyboard 键盘
│keyboard 'us'
│# timezone 时区(勾选了"Use UTC clock" 会追加[--isUtc])
│timezone Asia/Shanghai
│# Root password
│rootpw --iscrypted $1$DBk7xfJp$Agxd303XUAfRKIf7gB8DG/
└──────────────────────────────────────────────────────────┘
┌────────────────────────────────────────────────────────┐
│#Advanced Configuration   
│勾选就有,不勾没有
│========================================================
│# Reboot after installation
│reboot
│# Use text mode install
│text
└────────────────────────────────────────────────────────┘
  1. Installation Method

最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)
配置文件如下

┌────────────────────────────────────────────────────────┐
│#Installation Method         
│========================================================
│# Install OS instead of upgrade
│install
3. Boot Loader Options
配置文件如下
│# Upgrade existing installation
│upgrade
└────────────────────────────────────────────────────────┘
┌────────────────────────────────────────────────────────┐
│#Installation source  
│选了哪项就写哪项
│========================================================
│# Use CDROM installation media
│cdrom
│# Use NFS installation media
│nfs --server=服务器 --dir=目录
│# Use network installation
│url --url="ftp://用户名:密码@服务器/目录"
│# Use network installation
│url --url="http://服务器/目录"
│# Use hard drive installation media
│harddrive --dir=目录 --partition=分区
└────────────────────────────────────────────────────────┘
  1. Boot Loader Options

最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

配置文件如下

┌────────────────────────────────────────────────────────────────┐
│#Installation Method&GRUB options&Install Options
│=================================================================
│ ┌────────────────────────────────────┐
│ │ 选择了Do not install a boot loader │
│ └────────────────────────────────────┘
│ # System bootloader configuration
│ bootloader --location=none
│
│ ┌────────────────────────────────────┐
│ │  选择了install new boot loader   │
│ └────────────────────────────────────┘
│ bootloader --append="ker" --location=mbr --password="123"
│#append是内核参数,location是bootloader安装位置,password是GRUB密码
└────────────────────────────────────────────────────────────────┘
net.ifnames=0
  1. Partition Information
    最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

配置文件如下

┌─────────────────────────────────────────────────────┐
│# Master Boot Record 
│#Master Boot Record选择了clear... 否则就没有       
│======================================================
│# Clear the Master Boot Record
│zerombr
└─────────────────────────────────────────────────────┘
┌─────────────────────────────────────────────────────┐
│# Partitions&Disk Label      
│======================================================
│# Partition clearing information
│clearpart --linux --initlabel
└─────────────────────────────────────────────────────┘
┌─────────────────────────────────────────────────────┐
│# Layout 分区
│part 挂载点  --fstype=文件系统  --size=大小(单位M)    
│======================================================
│# Disk partitioning information
│part / --fstype="xfs" --size=10240
│part /boot --fstype="ext4" --size=1024
│part swap --fstype="swap" --size=2048
└─────────────────────────────────────────────────────┘
  1. Network Configuration

最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

配置文件如下

eth0

Langqq123

┌─────────────────────────────────────────────────────┐
│# Network Configuration
│Centos7如果要写eth0,要加内核参数net.ifnames=0
│======================================================
│# Network information
│network  --bootproto=dhcp --device=eth0
└─────────────────────────────────────────────────────┘
  1. Authentication

最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)
配置文件如下

┌───────────────────────────────────────────────────────────────┐
│# Authentication
│如果勾选Enable Fingerprint reader则追加参数 --enablefingerprint
│===============================================================
│# System authorization information
│auth  --useshadow  --passalgo=md5
└───────────────────────────────────────────────────────────────┘
  1. Firewall Configuration
    最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

配置文件如下

┌───────────────────────────────────────────────────────────────┐
│# Firewall Configuration
│===============================================================
│# SELinux configuration
│selinux  --disabled或permissive或enforcing
│
│# Firewall configuration
│firewall  --disabled或enabled
│#如果是enable,可以在追加:--http --ftp --telnet --smtp --ssh
│#还可以追加端口:--port=555:tcp,444:udp
└───────────────────────────────────────────────────────────────┘
  1. Display Configuration
    最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)
    配置文件如下

┌───────────────────────────────────────────────────────────────┐
│# Display Configuration
│===============================================================
│如果选了安装图形界面,就没有下面这句话
│# Do not configure the X Window System
│skipx 
│# Run the Setup Agent on first boot
│firstboot --enable或disable
└───────────────────────────────────────────────────────────────┘
  1. Package Selection
    最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

如果包安装的界面不出现可选的包信息,那么需要修改yum仓库配置文件

[root@centos ~]#vim /etc/yum.repos.d/***.repo
[development]
#把原来"[]"内的内容改成development,其它不变

配置文件如下

%packages
@development
-byacc
-cscope
-ctags
-diffstat
-doxygen
-elfutils
-gcc-gfortran
-git
-indent
-intltool
-patchutils
-rcs
-subversion
-swig
-systemtap
%end
  1. Pre-Installation Script
    最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

配置文件如下

%pre
echo i am pre
%end
  1. Post-Installation Script
    最全的自动系统安装centos.,kickstar+PXE.自动化安装centos系统(上)

配置文件如下

%post --nochroot
echo i am post
%end

12 以上system-config-kickstart 执行后最终生成的kickstart文件如下

#platform=x86, AMD64, or Intel EM64T
#version=DEVEL
# Install OS instead of upgrade
install
# Keyboard layouts
keyboard 'us'
# Root password
rootpw --iscrypted $1$2TeoFGRN$EeykyMirEiMIya57QmbG71
# Use network installation
url --url="http://192.168.100.7/Centos/7/os/x86_64"
# System language
lang zh_CN
# System authorization information
auth  --useshadow  --passalgo=sha512
# Use text mode install
text
# Run the Setup Agent on first boot
firstboot --enable
# SELinux configuration
selinux --disabled
# Do not configure the X Window System
skipx
# Firewall configuration
firewall --disabled
# Network information
network  --bootproto=dhcp --device=eth0
# Reboot after installation
reboot
# System timezone
timezone Asia/Shanghai
# System bootloader configuration
bootloader --append="net.ifnames=0" --location=mbr
# Clear the Master Boot Record
zerombr
# Partition clearing information
clearpart --all --initlabel
# Disk partitioning information
part /boot --fstype="ext4" --size=2048
part / --fstype="xfs" --size=10240
part swap --fstype="swap" --size=2048
%pre
i am pre
%end
%post --nochroot
i am post
%end
%packages
@development
-byacc
-cscope
-ctags
-diffstat
-doxygen
-elfutils
-gcc-gfortran
-git
-indent
-intltool
-patchutils
-rcs
-subversion
-swig
-systemtap
%end

完成后 可以进行语法检查

root@centos7 ~]#vim kstest.cfg
root@centos7 ~]#ksvalidator kstest.cfg
#需要安装pyksvalidator

PXE 自动化安装系统部署见下篇,感谢阅读.

展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
在线直播报名
返回顶部
顶部