centOS封装

前言

在实际工作中,CentOS的安装需要设置的语言、键盘模式、时区等信息都存在很大程度上的雷同型。并且,安装完成后的一些设置工作也都是一样的。这些工作都可以在安装操作系统的时候自动完成。最终做到,安装完成即可得到一个可以使用的CentOS系统。

理论描述

Kickstart安装提供一个安装过程自动化的方法,可以是部分自动化,也可以是完全自动化。Kickstart文件包含所有安装程序会问到的问 题答案,比如您要在系统中使用的时区、如何对驱动器进行分区、或者应该安装哪些软件包。因此为安装程序提供准备好的Kickstart文件,就可以让安装 程序自动执行安装,而不需要用户介入。这在同时向大量系统中部署Red Hat Enterprise Linux时特别有用。

可将Kickstart文件保存在独立服务器系统中,并由每台计算机在安装过程中读取。这个安装方法可支持单一Kickstart文件在多个机器中安装Red Hat Enterprise Linux,使其成为网络和系统管理员的理想工具。

CentOS作为RHEL的社区版本,同样支持Kickstart机制。在安装时,如果指定了安装使用的ks.cfg文件,并且将安装过程中所需要的软件包都封装在ISO里面。就可以实现操作系统的自动安装。

ks.cfg文件同样支持在安装完成后,执行一些系统配置相关的脚本。通过此功能,可以到将一些通用配置工作自动完成。

操作步骤

准备封装环境

安装全新的一个CentOS系统,这里选择CentOS 6.6。下载其DVD镜像,使用VMware Workstation安装。选择软件包时,推荐选择minimal的安装角色。然后,在定制界面勾选Base软件组。推荐使用minimal版本的 CentOS默认安装,链接如下:

http://mirrors.sohu.com /linux/centos/6/isos/x86_64/CentOS-6.6-x86_64-minimal.iso

安装完成后,启动这个虚拟机。并将其DVD状态设置为启用,以便于在虚拟机中挂载磁盘。

通过putty或者SecureCRT登录刚刚安装好的CentOS系统。启用虚拟机的网络,使其可以在线安装软件包。

通过如下命令,挂载CDROM

mkdir /mnt/cdrom
mount /dev/cdrom /mnt/cdrom

在系统中创建文件夹,以作为定制版CentOS的ISO文件的根目录

mkdir /srv/CentOS

将CDROM中的文件复制到此目录下。

cp -rp /mnt/cdrom /srv/CentOS/
cp /mnt/cdrom /.*info  /srv/CentOS

此时CentOS目录下的文件当类似如下所示:

[[email protected] ~]# ll -a /srv/CentOS
total 91
dr-xr-xr-x. 7 root root  4096 Oct 24 22:22 .
drwxr-xr-x. 6 root root  4096 Nov 10 22:29 ..
-r--r--r--. 1 root root    14 Oct 24 21:59 CentOS_BuildTag
-r--r--r--. 1 root root    33 Oct 24 22:13 .discinfo
dr-xr-xr-x. 3 root root  2048 Oct 24 22:12 EFI
-r--r--r--. 1 root root   212 Nov 28  2013 EULA
-r--r--r--. 1 root root 18009 Nov 28  2013 GPL
dr-xr-xr-x. 3 root root  2048 Oct 24 22:22 images
dr-xr-xr-x. 2 root root  2048 Oct 24 22:12 ISOlinux
dr-xr-xr-x. 2 root root 40960 Oct 24 22:22 Packages
-r--r--r--. 1 root root  1354 Oct 20 00:00 RELEASE-NOTES-en-US.html
dr-xr-xr-x. 2 root root  4096 Oct 24 22:22 repodata
-r--r--r--. 1 root root  1706 Nov 28  2013 RPM-GPG-KEY-CentOS-6
-r--r--r--. 1 root root  1730 Nov 28  2013 RPM-GPG-KEY-CentOS-Debug-6
-r--r--r--. 1 root root  1730 Nov 28  2013 RPM-GPG-KEY-CentOS-Security-6
-r--r--r--. 1 root root  1734 Nov 28  2013 RPM-GPG-KEY-CentOS-Testing-6
-r--r--r--. 1 root root  3380 Oct 24 22:22 TRANS.TBL
-r--r--r--. 1 root root   276 Oct 24 22:22 .treeinfo

安装创建软件库,制作ISO等用途使用的工具

yum install wget anaconda repodata createrepo mkisofs yum-plugin-downloadonly -y

定义自动应答

从用户根目录复制安装系统时自动创建的ks应答文件到CentOS目录下

cp /root/anaconda-ks.cfg /srv/CentOS/isolinux/ks.cfg

修改其内容为如下所示:

[[email protected] ~]# cat /srv/CentOS/isolinux/ks.cfg
# Kickstart file automatically generated by anaconda.

#version=DEVEL
install   #安装模式
cdrom   #从CDROM中安装
lang en_US.UTF-8  #使用英语语言
keyboard us  #使用美国键盘
network --onboot yes --bootproto dhcp  开机启用DHCP网络
rootpw  --iscrypted 6$tEOtj.d19Z6.9u2P$b6sUz3Bj7hiiJ6DD06SFRT8HVlXO5vJEsGALnpwpzMAS5bi95agSYEaRo4tr2Bj9wrKiL.IcYbF6NqYbif.d0/   #设置root密码为centos
firewall --service=ssh  #启用防火墙,允许ssh服务
authconfig --enableshadow --passalgo=sha512  #启用本地配置的用户授权配置
selinux --enforcing  #启用SELinux
timezone --utc Asia/Shanghai  #设置时区为亚洲上海
reboot #安装完成后重启
%packages --ignoremissing  #忽略找不到的安装包
@base
@core
@console-internet
tree
policycoreutils-python   #安装Selinux调试工具
ftp.xiyang-liu.com-CentOS-repos  #使用自己封装的repo文件
salt-minion  #安装saltstack客户端
%post --log=/root/ks-post.log  #安装后执行脚本,启用日志
sed -i -e‘s/^#master: salt/master: salt-master.xiyang-liu.com/g‘ /etc/salt/minion
#设置salt主服务器地址
chkconfig salt-minion on #开机启用saltstack客户端服务
%end

准备软件包

yum -y --downloadonly --downloaddir=/srv/CentOS/Packages groupinstall core
yum -y --downloadonly --downloaddir=/srv/CentOS/Packages groupinstall console-internet
yum -y --downloadonly --downloaddir=/srv/CentOS/Packages groupinstall base
yum -y --downloadonly --downloaddir=/srv/CentOS /Packages install tree
yum -y --downloadonly --downloaddir=/srv/CentOS /Packages install salt-minion
yum -y --downloadonly --downloaddir=/srv/CentOS /Packages install policycoreutils-python
wget http://ftp.xiyang-liu.com/linux/ftp.xiyang-liu.com-CentOS-repos-6-6.noarch.rpm -P /srv/CentOS /Packages  #自己封装的rpm包,内包含一组内网的repo源文件

更新软件库索引

在安装的过程中,我们添加了新软件,并且使用了CentOS默认的group分组信息进行安装。所以,要删除原有的软件库索引,通过createrepo命令重新创建软件库索引。

原有软件库信息包含如下文件

[[email protected] CentOS]# ls /srv/CentOS/repodata/
1178543d0c796123b61389f85e9bfb499cc37d09ffd6660a7dc48abb08ebd1f1-filelists.xml.gz
1942281fc19bc08ef30482f369826958917216990c7cf58749ac79d8a2a7ad47-other.sqlite.bz2
22df42595558712f571c91cbc49657ad7187a2a7990510e9c8883b5358ae2e16-primary.sqlite.bz2
460862ca0e99160b41eecc41b944eb2abc0b82609bd12407bc5609922627eac4-comps.xml.gz
4b60435c2aa393f4678e7f47a3e0ec3324c50d47cc59dc1b7d439dd6f2ceeda8-filelists.sqlite.bz2
7f916b09f7bde0b0396266f9dddd49ae679d116ee68529bbf0feb63cbdf288dd-other.xml.gz
9e2ddcc42b44eb150ebc61dde29c997318d8330b92205b3dbb3a87bcc06d10be-comps.xml
b047f47dcdfe466ea868dadba0cdde1038517a335e17e4aaf5afc7d78288ccca-primary.xml.gz
repomd.xml

备份原有分组信息:

mv /srv/centos/repodata/*-comps.xml /srv/comps.xml

删除现有软件库索引

rm -r /srv/CentOS/repodata/*

创建新索引

discinfo=`head -1 .discinfo ` ; createrepo -u "media://$discinfo" -g /srv/comps.xml /srv/CentOS/

修改ISOLINUX启动文件

软件包准备完成后,修改ISOLINUX启用器。使其启动时自动使用应答文件进行安装。修改至如下所示:

[[email protected] srv]# cat /srv/CentOS/isolinux/isolinux.cfg
label linux
menu label ^Install or upgrade an existing system
menu default
kernel vmlinuz
append<strong> ks=cdrom:/isolinux/ks.cfg </strong>initrd=initrd.img

创建ISO文件

cd /srv/CentOS/
mkisofs -o /srv/CentOS-6.6-xiyang-liu-x86_64.iso -b isolinux/isolinux.bin -c isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table -R -J -v -T /srv/CentOS/

结语

本文档描述了以CentOS minimal安装为基础环境,通过修改ks.cfg文件的形式,定制具有特殊配置的CentOS系统。

参考链接

Kickstart 安装-红帽安装文档

https://access.redhat.com/documentation/zh-CN/Red_Hat_Enterprise_Linux/7/html/Installation_Guide/chap-kickstart-installations.html

https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/6/html/Installation_Guide/ch-kickstart2.html

centos定制-oschina-_sylee
http://my.oschina.net/sylee/blog/167759

时间: 2024-07-28 22:30:38

centOS封装的相关文章

阿里云服务器上架设apache php mysql 环境

由于朋友一公司要做企业站,于是就买了阿里云的服务器.买完进去发现iptables 和selinux默认就是关掉的,可能是因为阿里云有云盾就可以不用自带的防火墙吧,具体配置过程如下(我边配边记录的): 1,生成yum 缓存: yum makecache 速度蛮不错,生成蛮快 2,安装apache,centos 封装apache为httpd了,直接安装就可以 yum install httpd 安装完后,开机默认启动该服务 chkconfig httpd on 现在启动服务 service http

centos 系统裁剪与iso重新封装

a.在VM安装linux系统 b.安装定制工具anaconda repodata createrepo mkisofs c.关联太多采用yum安装 定制过程需要产生comps.xml文件以及生成iso 1.定制安装系统,选择常用的组件 2.安装制作发行版所需的基本软件包 yum install -y createrepo genisoimage #genisoimage 提供/usr/bin/mkisofs 命令用于重新生成iso 3.生成安装系统所需的rpm文件列表 awk '/Install

Centos下安装memcached+memcached教程

Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据.简单的说就是将

CentOS 6.5 安装部署iSCSi共享存储

 CentOS 6.5 安装部署iSCSi共享存储 一.前言 1.什么是iSCSI? iSCSI技术是一种由IBM公司研究开发的,是一个供硬件设备使用的可以在IP协议的上层运行的SCSI指令集,这种指令集合可以实现在IP网络上运行SCSI协议,使其能够在诸如高速千兆以太网上进行路由选择.iSCSI技术是一种新储存技术,该技术是将现有SCSI接口与以太网络(Ethernet)技术结合,使服务器可与使用IP网络的储存装置互相交换资料. iSCSI:Internet 小型计算机系统接口 (iSCSI:

docker入门(1) Centos 7 下docker的安装

centos 7安装docker 什么是 Docker Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目.它基于 Google 公司推出的 Go 语言实现. 项目后来加入了 Linux 基金会,遵从了 Apache 2.0 协议,项目代码在 GitHub 上进行维护. Docker 自开源后受到广泛的关注和讨论,以至于 dotCloud 公司后来都改名为 Docker Inc.Redhat 已经在其 RHEL6.5 中集中支持 Docker:

CentOS 6.3下配置LVM(逻辑卷管理)

一.简介 LVM是逻辑盘卷管理(Logical Volume Manager)的简称,它是Linux环境下对磁盘分区进行管理的一种机制,LVM是建立在硬盘和分区之上的一个逻辑层,来提高磁盘分区管理的灵活性. LVM的工作原理其实很简单,它就是通过将底层的物理硬盘抽象的封装起来,然后以逻辑卷的方式呈现给上层应用.在传统的磁盘管理机制中,我们的上层应用是直接访问文件系统,从而对底层的物理硬盘进行读取,而在LVM中,其通过对底层的硬盘进行封装,当我们对底层的物理硬盘进行操作时,其不再是针对于分区进行操

烂泥:Centos上使用PPTP搭建VPN

本文首发于烂泥行天下. 目前公司在IDC机房有一台服务器A(linux系统).该服务器是对外的有两块网卡,一个是公网,一个是私网的. 而另外一台服务器B必须通过A服务器上的VPN拨连接进来,才能管理服务器B. 但是A服务器上通过iptables策略限制,只能是公司的IP地址才能通过VPN拨号连接进来. 这样就相应的提高了服务器的安全性,下面记录下有关A服务器VPN的安装与配置. 介绍下PPTP的相关知识: PPTP(点到点隧道协议)是一种用于让远程用户拨号连接到本地的ISP,通过因特网安全远程访

centos 6.9 编译安装 Nginx1.12.1

centos 6.9 使用yum 安装 Nginx1.12.1 Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日. 其将源代码以类BSD许可证的形式发布,因它的稳定性.丰富的功能集.示例配置文件和低系统资源的消耗而闻名.2011年6月1日,nginx 1.0.4发布. Ng

linux(centos)上搭建pppoe服务器

搭建pppoe,成功了的话,就觉得TM超级简单,在centos更是5步左右就能搞定 1.安装pppoe,安装完成后,会有pppoe-server命令 yum install rp-pppoe 2.安装完成后,会在动在/etc/ppp目录下生成pppoe-server-options文件,文件内容如下,照着改就可以了 写道 # PPP options for the PPPoE server # LIC: GPL require-pap require-chap login lcp-echo-in