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]# lsCentOS_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]# lsboot.cat boot.msg grub.conf initrd.img isolinux.bin isolinux.cfg memtest splash.png TRANS.TBL upgrade.img vesamenu.c32 vmlinuz[root@centos7 isolinux]# lltotal 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=
FTP server: ks=
HTTPS server:ks=
NFS server: ks=nfs:host:/path/to/KICKSTART_FILE
☉启动救援模式:
rescue
☉装载额外驱动:
dd
☉官方文档
《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=DEVELinstall # 安装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 installationreboot # 安装完成之后的行为firewall --disabled # 防火墙authconfig --useshadow --passalgo=sha512 # 认证方式配置selinux --disabled # SElinuxtimezone 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=20480repo --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下退出;
需要注意这里在分区时一定选择清除主引导分区,删除所有分区和初始化磁盘卷标,要不然在自动化安装时会提醒你是否清除数据
3.查看root下生成的文件,并检查语法错误,如下:
[root@CentOS6 ~]# lsanaconda-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 ~]# lsanaconda-ks.cfg bin boot.iso # 生成的镜像文件 Desktop Documents Downloads f1 Music myks.cfg Pictures Public Templates Videos
2.新建一个虚拟机,用创建好的光盘镜像在虚拟机上重新引导安装,如下:
3.成功安装: