linux安装详解-配置ks.cfg实现自动安装过程

每个优秀的人,都有一段沉默的时光。那一段时光,是付出了不少努力,忍受孤独和寂寞,不抱怨不诉苦,往后提及时,连本身都能被感动日子。linux

                                                        --马哥语录express

以前发过一篇关于经过PEX实现linux批量无人值守自动安装的博文,不过写的只是具体的配置和操做,对于原理部分没有说明,最近经过一段时间的学习,把linux的启动安装过程深刻的了解了下,这里还要特别感谢马哥的指导centos

言归正传,下面开始深刻探讨linux的安装网络

linux安装大体能够分为2个阶段less

第一阶段:anacondadom

第二阶段:installinstall阶段系统会按照anaconda阶段设定的参数自动安装,这里主要要说的是anaconda阶段,此阶段是linux的预安装环境,提供linux安装选项的一个接口,能够将它比做是window中的PE环境ssh

anaconda有两种模式:交互式和非交互式ide

交互式就和普通安装同样,按照提示选择选项一步步的安装工具

非交互式则经过读取kickstart文件的配置,进行自动安装,这和window中的无人值守安装差很少的,这个文件便是ks.cfg文件(至关于window中的wi2k3.sif应答文件)post

而在安装linux过程当中,获取ks.cfg文件的方式有多种,如直接在cdrom中获取,常见的形式还有http,ftp,nfs等方式

格式有三种:

cdrom和硬盘

ks=cdrom:/dir/ks.cfg(硬盘的话把cdrom换成hd便可,下面的相似)

http和ftp

ks=http://domain.com/dir/ks.cfg

NFS

ks=nfs:domain.com:/dir/ks.cfg

三种格式主要区分在于后面的斜杠,这里要注意区分

 

在使用ks.cfg以前,须要先引导启动环境

引导方式有不少,cdrom,usb,PXE等。

在引导进入anaconda后,便可经过读取ks.cfg来进行系统的自动安装

这里开始说说kickstart文件的大体内容

ks.cfg文件组成大体分为3段

1.命令段:

键盘类型,语言,安装方式等系统的配置,有必选项和可选项,若是缺乏某项必选项,安装时会中断并提示用户选择此项的选项

2.软件包段:

%packages

@groupname:指定安装的包组

package_name:指定安装的包

-package_name:指定不安装的包

在安装过程当中默认安装的软件包,安装软件时会自动分析依赖关系。

3.脚本段(可选):

%pre:预安装脚本(因为只依赖于启动镜像,支持的命令不多)

%post:后安装脚本(基本支持全部命令)

 

而具体的ks.cfg文件的配置,咱们只须要在已经安装好的linux的root家目录找到anaconda_ks.cfg(这个ks文件就是在安装linux后,根据用户的安装选项自动生成的)

下面的是个人一个样例

 

(系统是CentOS-6.2-i386-minimal,因此配置样例比较精简)

 

  
  
  
  
  1. # Kickstart file automatically generated by anaconda. 
  2.  
  3. #version=DEVEL 
  4.  
  5. install  #表示是安装,而不是升级 
  6.  
  7. text #文本方式安装 
  8.  
  9. cdrom #安装方式,若是是网络安装的话能够写成 url ––url ftp://192.168.1.254/dir 或者 nfs --server=192.168.0.241 --dir=/centosinstall 
  10.  
  11. key –skip #这个是我另外添加的,若是是redhat的系统,会要求输入key,这里配置为跳过,若是不配置安装时会停在那里要求用户输入key 
  12.  
  13. lang en_US.UTF-8  #语言 
  14.  
  15. keyboard us #键盘样式 
  16.  
  17. network --onboot no --device eth0 --noipv4 --noipv6 #网络配置 配置具体参数样例:network –onboot yes --bootproto=static --ip=192.168.1.1 --netmask=255.255.255.0 其余网关,DNS等格式和ifcfg-ethx的方式同样 
  18.  
  19. rootpw  --iscrypted $6$PEJ49S7OkrNra3UM #管理员密码,是加密过的 要是使用不加密的方式则这样写:rootpw 123456 

  20. firewall --service=ssh #开启防火墙,并打开ssh端口 
  21.  
  22. authconfig --enableshadow --passalgo=sha512 #用户认证和密码加密方式 
  23.  
  24. selinux --enforcing #强制打开selinux 
  25.  
  26. timezone --utc Etc/GMT+8 #时区设置 
  27.  
  28. zerombr yes #清空磁盘的mbr 
  29.  
  30. bootloader --location=mbr --driveorder=sda #引导程序相关参数 
  31.  
  32. # The following is the partition information you requested 
  33. # Note that any partitions you deleted are not expressed 
  34. # here so unless you clear all partitions first, this is 
  35. # not guaranteed to work 
  36.  
  37. clearpart –all –initlabel #初始化磁盘 
  38.  
  39. part / --fstype=ext4 --size=18000 #开始分区 
  40. part swap --grow --size=1024 
  41. repo --name="CentOS"  --baseurl=cdrom:sr0 --cost=100 
  42.  
  43. reboot 
  44.  
  45.  
  46. %packages --nobase #安装的软件包,这里因为我安装的是最小mini版,因此只安装了核心软件包组 
  47. @core 
  48.   
  49.  
  50. %post #后安装脚本(这里是我另外添加的,原来文件中没有) 
  51. id lustlost &>; /dev/null || useradd lustlost #检查是否有lustlost用户,若是没有则添加 
  52. echo 123456 | passwd –stdin lustlost #配置密码 
  53.  
  54. cat >> /etc/yum.repos.d/base.repo << eof 
  55. [base] 
  56. name=baseserver 
  57. baseurl=http://192.168.1.254/yum 
  58. gpgcheck=0 
  59. enable=1 
  60. eof                                 #这里在安装系统成功后执行脚本自动配置一个yum源,其余脚本能够按照须要定义 
  61.  
  62. %end 

若是以为使用样本的方式手工写配置文件比较麻烦,也可使用图形化工具来制做ks.cfg文件

在linux中用yum安装system-config-kickstart就好了(图形化依赖于x-window),选项也有些限制(好比分区不能使用lvm),这里就再也不演示了

相关文章
相关标签/搜索