CentOS 系统自动化安装

==============================================================================

概述:

  • 系统安装过程

  • 配置anaconda

  • 自动化安装系统

==============================================================================

CentOS 系统安装

 1.启动流程:

启动流程

  • bootloader-->kernel(initrd)-->rootfs-->anaconda(启动安装程序)

 2.anaconda:(系统安装程序)

安装界面:

  • tui:基于cureses的文本配置窗口;

  • gui:图形界面

anaconda介绍

  • Anaconda是RedHat、CentOS、Fedora等Linux的安装管理程序。它可以提供文本、图形等安装管理方式,并支持 Kickstart 等脚本提供自动安装的功能。此外,其还支持许多启动参数,熟悉这些参数可为安装带来很多方便。该程序的功能是把位于光盘或其他源上的数据包,根据设置安装到主机上。为实现该定制安装,它提供一个定制界面,可以实现交互式界面供用户选择配置(如选择语言,键盘,时区等信息)。

  • Anaconda的大部分模块用Python编写,有少许的载入模块用C编写。

 3.CentOS的安装过程启动流程:

MBR:boot.cat

Stage2:isolinux/isolinux.bin

配置文件:isolinux/isolinux.cfg

  • 每个对应的菜单选项

  • 加载内核:isolinux/vmlinuz

  • 向内核传递参数:append initrd=initrd.img

  • 其实整个光盘安装启动过程就是依赖于isolinux这个目录下的文件的

装载根文件系统,并启动anaconda

默认界面是图形界面(GUI):

  • 512MB+内存空间

若需要显示指定启动TUI接口:向启动内核传递一个参数“text”即可;

      1)按tab键:在后面增加text

      2)按ESC键:boot(提示符下): linux text

注意:

上述内容一般位于引导设备,例如可通过光盘、U盘、或网络等;后续的anaconda及其安装用到的程序包等可以来自于程序包仓库。

此仓库的位置可以为:

  • 本地光盘、本地硬盘、ftp server、http server、nfs server

  • 如果想手动指定安装仓库:按 ESC键:boot(提示符下):linux method

演示:

[root@centos7 ~]# cd /misc/cd
[root@centos7 cd]# ls
CentOS_BuildTag  EFI  EULA  GPL  p_w_picpaths  isolinux  LiveOS  Packages  repodata  RPM-GPG-KEY-CentOS-7  RPM-GPG-KEY-CentOS-Testing-7  TRANS.TBL
[root@centos7 cd]# cd isolinux/
[root@centos7 isolinux]# ls
boot.cat  boot.msg  grub.conf  initrd.img  isolinux.bin  isolinux.cfg  memtest  splash.png  TRANS.TBL  upgrade.img  vesamenu.c32  vmlinuz
[root@centos7 isolinux]# ll
total 86002
-r--r--r-- 1 root root     2048 Dec 10  2015 boot.cat
-r--r--r-- 1 root root       84 Dec 10  2015 boot.msg
-r--r--r-- 1 root root      281 Dec 10  2015 grub.conf
-r--r--r-- 2 root root 38508192 Dec 10  2015 initrd.img
-r--r--r-- 1 root root    24576 Dec 10  2015 isolinux.bin
-r--r--r-- 1 root root     3032 Dec 10  2015 isolinux.cfg
-r--r--r-- 1 root root   176500 Sep 11  2014 memtest
-r--r--r-- 1 root root      186 Oct  1  2015 splash.png
-r--r--r-- 1 root root     2438 Dec 10  2015 TRANS.TBL
-r--r--r-- 2 root root 44035836 Dec 10  2015 upgrade.img
-r--r--r-- 1 root root   153104 Mar  6  2015 vesamenu.c32
-r-xr-xr-x 2 root root  5156528 Nov 20  2015 vmlinuz

[root@centos7 isolinux]# less isolinux.cfg 
...
label linux
  menu label ^Install CentOS 7
  kernel vmlinuz  # 加载的内核
  append initrd=initrd.img inst.stage2=hd:LABEL=CentOS\x207\x20x86_64 quiet # 向内核传递的参数

anaconda 工作过程(安装前配置阶段,安装阶段,首次启动)

 1.安装前配置阶段:

  • 安装过程使用的语言;

  • 键盘类型;

  • 安装目标存数设备;

           Basic Storage:本地磁盘

           Special Storage:ISCSI

  • 设定主机名;

  • 配置网络接口;

  • 时区;

  • 管理员密码;

  • 设定分区方式及MBR的安装位置;

  • 创建一个普通用户;

  • 选定要安装的程序包;

 2.安装阶段:

  • 在目标磁盘创建分区并执行格式化;

  • 将选定的程序包安装至目标位置;

  • 安装bootloader

 3.重启系统

  • iptables 防火墙 

  • selinux 

  • core dump 核心转储

安装引导选项及 kickstart 文件

 1.anaconda 的配置方式:

配置方式:

  • 交互式配置方式;

  • 支持通过读取配置文件中事先定义好的配置项自动完成配置;遵循特定的语法格 式,此文件即为kickstart文件;

 2.安装引导选项:

boot:

text:文本安装方式;

method:手动指定使用安装方法;

与网络相关的引导选项:

  • ip=IPADDR

  • netmask=MASK

  • gateway=GW

  • dns=DNS_SERVER_IP

  • ifname=NAME:MAC_ADDR

远程访问功能相关的引导选项:

  • vnc

  • vncpassword='PASSWORD'

指明kickstart文件的位置:ks=

  • DVD drive:   ks=cdrom:/PATH/TO/KICKSTART_FILE

  • Hard drive:  ks=hd:device:/directory/KICKSTART_FILE

  • HTTP server: ks=http://host:port/path/to/KICKSTART_FILE

  • FTP server:  ks=ftp://host:port/path/to/KICKSTART_FILE

  • HTTPS server:ks=https://host:port/path/to/KICKSTART_FILE

  • NFS server:  ks=nfs:host:/path/to/KICKSTART_FILE

启动救援模式:

  • rescue

装载额外驱动:

  • dd

官方文档

  • www.redhat.com/docs 《installation guide》 

 3.kickstart文件的格式

命令段指定各种安装前的配置选项,如键盘类型等;

  • 必备命令

  • 可选命令

程序包段:指明要安装程序包,以及包组,也包括不安装的程序包;

  • %packages :指明程序包段的开始;

  • @group_name:安装一个包组;

  • package:安装一个程序包;

  • -package :指明不安装的程序包;

  • %end :指明程序包段的结尾;

脚本段:

  • %pre:安装前脚本

  • 运行环境:运行于安装介质上的微型Linux环境

  • %post:安装后脚本

  • 运行环境:安装完成的系统;

 4.命令段中的必备命令及可选命令

必备命令

authconfig:认证方式配置;

  • authconfig--useshadow--passalgo=sha512

bootloader:bootloader的安装位置及相关配置;

  • bootloader --location=mbr --driveorder=sda --append="crashkernel=auto rhgb quiet"

keyboard: 设定键盘类型;

lang: 语言类型; 如:lang zh_CN.UTF-8

part: 分区布局;

  • part /boot --fstype=ext4 --size=200

  • part pv.008002 --size=61440

补充:分区相关的其他命令:

  • clrarpart:清除分区;(clearpart --none --drives=sda:清空磁盘分区

  • volgroup:创建卷组;(volgroup vg0 --pesize=8192 pv.008002

  • logvol:创建逻辑卷;(logvol / --fstype=ext4 --name=root --vgname=vg0 --size=20480

rootpw:指明root的密码;

timezone:时区  timezone Asia/Shanghai

可选命令

install OR upgrade;安装或升级

text: 安装界面类型,text为TUL,默认为GUI

network:配置网络接口;

firewall:防火墙

   系统安装完成之后禁用防火墙

CentOS 6 :

  • # service iptables stop

  • # chkconfig iptables off

CentOS 7 :

  • # systemctl stop firewalld.service

  • # systemctl disables firewalld.service

selinux:SElinux

  系统安装完成后禁用SElinux:

  • 编辑/etc/sysconfig/selinux或/etc/selinux/config文件,修改SELINUX参数的值为下面其中参数之一:permisslve,disabled

  • 立即生效:getenforce,setenforce 0  

安装完成之后的行为

  • halt、poweroff、reboot:;

repo:安装时使用的rpository

user:安装完成后为系统创建新用户

url:指明安装时使用的repository,但是为url格式;

key –skip:跳过安装号码,适用于rhel版本

演示:

 1.CentOS 6 中的 anaconda-ks.cfg

[root@CentOS6 ~]# cat anaconda-ks.cfg 
# Kickstart file automatically generated by anaconda.

#version=DEVEL
install      # 安装
url --url=    # 指明安装时使用的仓库 
lang en_US.UTF-8 # 指明使用的语言
keyboard us    # 指明使用的键盘
network --onboot yes --device eth0 --bootproto dhcp --noipv6 # 配置网络接口
rootpw  --iscrypted $6$CGsqab6d$Cd.PnnWtlL5XZAyr9J2zoMqyJH1QodcDp1pQp0uZ1f0Cq4eq9.TMkSQU6IfpvYZEYc32.lmF0lKuQwavnC49a0      # 指明root密码 
# Reboot after installation
reboot          # 安装完成之后的行为
firewall --disabled   # 防火墙
authconfig --useshadow  --passalgo=sha512 # 认证方式配置
selinux --disabled      # SElinux
timezone Asia/Shanghai    # 时区
bootloader --location=mbr --driveorder=sda --append="crashkernel=auto crashkernel=auto rhgb rhgb quiet quiet"  # bootloader的安装位置及相关配置
# Clear the Master Boot Record
#zerombr
# The following is the partition information you requested
# Note that any partitions you deleted are not expressed
# here so unless you clear all partitions first, this is
# not guaranteed to work
#clearpart --all

#part /boot --fstype=ext4 --size=200
#part pv.008002 --size=61440

#volgroup vg0 --pesize=8192 pv.008002
#logvol / --fstype=ext4 --name=root --vgname=vg0 --size=20480
#logvol swap --name=swap --vgname=vg0 --size=2048
#logvol /usr --fstype=ext4 --name=usr --vgname=vg0 --size=10240
#logvol /var --fstype=ext4 --name=var --vgname=vg0 --size=20480

repo --name="CentOS"  --baseurl=http://10.1.0.1/cobbler/ks_mirror/6/ --cost=100

定制kickstart文件的方式:

直接手动编辑;

  • 依据某模板修改

可使用创建工具:

  • # yum install system-config-kickstart

  • system-config-kickstart

  • 依据某模板修改并生成新配置;

检查ks文件的语法错误:ksvalidator

  • # ksvalidator /PATH/TO/KICKSTART_FILE

利用创建工具,操作如下:

1.~]# system-config-kickstart &    运行命令,会出现如下编辑界

 2.我们可以在编辑器上进行编辑,选择分区,网络,等配置,也可以导入模板文件(anaconda)在此基础上修改配置,并创建文件名,保存至root下退出;

   需要注意这里在分区时一定选择清除主引导分区,删除所有分区和初始化磁盘卷标,要不然在自动化安装时会提醒你是否清除数据

CentOS 系统自动化安装_第1张图片

 

  3.查看root下生成的文件,并检查语法错误,如下:

[root@CentOS6 ~]#  ls
anaconda-ks.cfg  bin  Desktop  Documents  Downloads  f1  ks.cfg # 生成的文件  Music  Pictures  Public  Templates  Videos
[root@CentOS6 ~]# ksvalidator ks.cfg  # 检查语法错误,有错误会报错




制作引导光盘

 1.创建引导光盘

  • # cp/media/cdrom/isolinux/ /tmp/myiso/

  • # vi /tmp/myiso/isolinux/isolinux.cfg

        initrd=initrd.imgtext ks=cdrom:/myks.cfg

  • # cp/root/myks.cfg /tmp/myiso/

  • # cd /tmp

  • # mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 --boot-info-table -V "CentOS 6.6 x86_64 boot" -b isolinux/isolinux.bin-c isolinux/boot.cat -o /root/boot.iso myiso/

演示步骤如下:

[root@CentOS6 ~]# mkdir  /tmp/myiso/
[root@CentOS6 ~]# cp -a /misc/cd/isolinux/ /tmp/myiso/ # 复制光盘下的isolinux到/tmp下
[root@CentOS6 ~]# cd /tmp/myiso/isolinux/
[root@CentOS6 isolinux]# ll  # 可以看到,因为是光盘文件所以都是只读的
total 44436
-r--r--r-- 1 root root     2048 Sep 13 12:11 boot.cat  
-r--r--r-- 1 root root       84 Sep 13 12:11 boot.msg
-r--r--r-- 1 root root      321 Sep 13 12:11 grub.conf
-r--r--r-- 1 root root 40688737 Sep 13 12:11 initrd.img  # 文件驱动
-r--r--r-- 1 root root    24576 Sep 13 12:11 isolinux.bin
-r--r--r-- 1 root root      923 Sep 13 12:11 isolinux.cfg  # 配置文件
-r--r--r-- 1 root root   183012 Sep 13 12:11 memtest
-r--r--r-- 1 root root   151230 Sep 13 12:11 splash.jpg  # 为背景图
-r--r--r-- 1 root root     2215 Sep 13 12:11 TRANS.TBL
-r--r--r-- 1 root root   163728 Sep 13 12:11 vesamenu.c32
-r-xr-xr-x 1 root root  4264528 Sep 13 12:11 vmlinuz  # 内核文件
[root@CentOS6 isolinux]# chmod u+w isolinux.cfg  # 添加写权限,进行修改
[root@CentOS6 isolinux]# vim isolinux.cfg

[root@CentOS6 tmp]# mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 --boot-info-table -V "CentOS 6.8 x86_64 boot" -b isolinux/isolinux.bin -c isolinux/boot.cat -o /root/boot.iso myiso/  # 注意一定退出myiso目录,创建光盘镜像,指明路径等信息,并在/root下生成一个boot.iso镜像
[root@CentOS6 ~]# ls
anaconda-ks.cfg  bin  boot.iso # 生成的镜像文件  Desktop  Documents  Downloads  f1  Music  myks.cfg  Pictures  Public  Templates  Videos

2.新建一个虚拟机,用创建好的光盘镜像在虚拟机上重新引导安装,如下:

CentOS 系统自动化安装_第2张图片

3.成功安装:

CentOS 系统自动化安装_第3张图片