Loading

102、定制专属操作系统


102.1、生产场景:

你到某个机房给服务器安装CentOS6的系统并搭建服务,你到现场发现服务器没有外网只有内网,而且没有内网yum仓库,kickstart或cobbler更不用想。

你手上仅有的工具是usb光驱或U盘。怎么搞定,做一个自动化安装的镜像,并把业务所有需要的依赖包全打包进去。

102.2、挂载镜像:

[root@m01 ~]# mount /dev/cdrom /mnt

mount: block device /dev/sr0 is write-protected, mounting read-only

[root@m01 ~]# df -h

Filesystem Size Used Avail Use% Mounted on

/dev/sda2 57G 2.3G 52G 5% /

tmpfs 296M 4.0K 296M 1% /dev/shm

/dev/sda1 190M 67M 114M 37% /boot

/dev/sr0 3.7G 3.7G 0 100% /mnt

[root@m01 ~]# cd /mnt

[root@m01 mnt]# ll -ah

总用量 567K

dr-xr-xr-x 7 root root 4.0K 8月 5 2015 .

dr-xr-xr-x. 25 root root 4.0K 12月 17 05:27 ..

-r--r--r-- 2 root root 14 8月 5 2015 CentOS_BuildTag

-r--r--r-- 1 root root 31 8月 5 2015 .discinfo #安装介质的识别信息文件;

dr-xr-xr-x 3 root root 2.0K 8月 5 2015 EFI

-r--r--r-- 2 root root 212 11月 27 2013 EULA

-r--r--r-- 2 root root 18K 11月 27 2013 GPL

dr-xr-xr-x 3 root root 2.0K 8月 5 2015 images #存放必要启动映像文件的目录;

dr-xr-xr-x 2 root root 2.0K 8月 5 2015 isolinux #存放光盘启动时安装界面信息的目录;

dr-xr-xr-x 2 root root 516K 8月 5 2015 Packages #存放安装软件包及信息的目录;

-r--r--r-- 2 root root 1.4K 7月 25 2015 RELEASE-NOTES-en-US.html

dr-xr-xr-x 2 root root 4.0K 8月 5 2015 repodata #存放rpm包依赖的信息;

-r--r--r-- 2 root root 1.7K 11月 27 2013 RPM-GPG-KEY-CentOS-6

-r--r--r-- 2 root root 1.7K 11月 27 2013 RPM-GPG-KEY-CentOS-Debug-6

-r--r--r-- 2 root root 1.7K 11月 27 2013 RPM-GPG-KEY-CentOS-Security-6

-r--r--r-- 2 root root 1.7K 11月 27 2013 RPM-GPG-KEY-CentOS-Testing-6

-r--r--r-- 1 root root 3.4K 8月 5 2015 TRANS.TBL

-r--r--r-- 1 root root 338 8月 5 2015 .treeinfo

102.3、收集rpm包:

[root@m01 mnt]# rsync -avz --exclude={Packages,repodata} /mnt/ /application/CentOS6/

[root@m01 CentOS6]# cd /application/CentOS6/

[root@m01 CentOS6]# ls

CentOS_BuildTag EULA images RELEASE-NOTES-en-US.html RPM-GPG-KEY-CentOS-Debug-6 RPM-GPG-KEY-CentOS-Testing-6

EFI GPL isolinux RPM-GPG-KEY-CentOS-6 RPM-GPG-KEY-CentOS-Security-6 TRANS.TBL

[root@m01 CentOS6]# du -sh

268M .

[root@m01 CentOS6]# mkdir -p /application/CentOS6/Packages

[root@m01 CentOS6]# cd ~

[root@m01 ~]# ls

anaconda-ks.cfg install.log install.log.syslog openvpn.log

[root@m01 ~]# awk '/Installing/{print "rsync -az /mnt/Packages/"$2".rpm /application/CentOS6/Packages/"}' install.log|bash #把当前操作系统中最初装系统时选定的软件通过挂载的镜像包中(/mnt)

拷贝到新的镜像中。

[root@m01 ~]# cd /mnt/Packages/

[root@m01 Packages]# \cp -av tree-1.5.3-3.el6.x86_64.rpm nmap-5.51-4.el6.x86_64.rpm sysstat-9.0.4-27.el6.x86_64.rpm lrzsz-0.12.20-27.1.el6.x86_64.rpm dos2unix-3.1-37.el6.x86_64.rpm telnet-0.17-48.el6.x86_64.rpm /application/CentOS6/Packages/ #增加新的软件包

[root@m01 Packages]# cd /application/CentOS6/

[root@m01 CentOS6]# du -sh

636M .

[root@m01 CentOS6]# ls Packages/ | wc -l #软件包个数

516

102.4、生成repodata目录:

[root@m01 CentOS6]# pwd

/application/CentOS6

[root@m01 CentOS6]# yum install createrepo -y #安装createrepo包;

[root@m01 CentOS6]# rpm -qa createrepo

createrepo-0.9.9-28.el6.noarch

[root@m01 CentOS6]# cp /mnt/repodata/4df092633ebecaeebdd78359a11a3c13f619f22605322e15e5e307beebd8e641-c6-x86_64-comps.xml comps.xml #复制comps文件

[root@m01 CentOS6]# createrepo -g comps.xml . #指定本地软件仓库的组划分,为Packages目录下的rpm包建立索引;

Spawning worker 0 with 516 pkgs

Workers Finished

Gathering worker results

Saving Primary metadata

Saving file lists metadata

Saving other metadata

Generating sqlite DBs

Sqlite DBs complete

[root@m01 CentOS6]# ls repodata/

0f9fa8678bade710bf334e6fee35bac83b14789b6b2de6313e9485d433595cda-other.sqlite.bz2

486d3ee62873814293a1be370640ae9c71863a35c7299eb76739e03369ad0c3f-comps.xml.gz

4df092633ebecaeebdd78359a11a3c13f619f22605322e15e5e307beebd8e641-comps.xml

622ef0bcb8d8d1f19606a25c0c31c4190d7221e1824d26298f9e7c3c0ee34a16-filelists.xml.gz

6bf0def1e8746b53b10bb67a116519ce047f64b605a5480f39184bdcc8c4e4ce-other.xml.gz

79e0d6b88259038c7f4bf27e5e183e13de6a95774e8854ed023d1bb922e98432-primary.xml.gz

908d6f9e712fd0a295f7f93067f8cd7a0c79aad971aa3939d01411658f156569-filelists.sqlite.bz2

bc2f2d4b6c814468efc4e2614b12a3cc5a958de463cb5c3caabcb8b618b5031f-primary.sqlite.bz2

102.4.1、repodata文件中的comps.xml文件中包含了 安装时所建的与rpm相关的内容,它会检查Packages下的rpm包的依赖关系,安装时如果

缺少相关的依赖包,它会提示您哪个rpm包需要哪些依赖库,同时它的角色相当于图形安装时选择软件包的环节;

102.5、定制kickstart安装脚本ks.cfg文件:

[root@m01 ~]# vim /application/CentOS6/isolinux/ks.cfg #定制的启动脚本;

# Kickstart Configurator for CentOS 6.7 by lc

install

cdrom

text

lang en_US.UTF-8

keyboard us

zerombr

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

network --bootproto=dhcp --device=eth0 --onboot=yes --noipv6 --hostname=CentOS6

timezone --utc Asia/Shanghai

authconfig --enableshadow --passalgo=sha512

rootpw --iscrypted $6$X20eRtuZhkHznTb4$dK0BJByOSAWSDD8jccLVFz0CscijS9ldMWwpoCw/ZEjYw2BTQYGWlgKsn945fFTjRC658UXjuocwJbAjVI5D6/

clearpart --all --initlabel

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

part swap --size=1024

part / --fstype=ext4 --grow --asprimary --size=200

firstboot --disable

selinux --disabled

firewall --disabled

logging --level=info

reboot

%packages

@base

@compat-libraries

@debugging

@development

tree

nmap

sysstat

lrzsz

dos2unix

telnet

iptraf

ncurses-devel

openssl-devel

zlib-devel

OpenIPMI-tools

screen

%end

%post

>/etc/issue

echo 'welcome lc linux' >/etc/motd

%end

[root@m01 ~]# vim /application/CentOS6/isolinux/isolinux.cfg #默认的启动脚本

label linux

menu label ^Auto Install LC Linux system

menu default

kernel vmlinuz

append ks=cdrom:/isolinux/ks.cfg initrd=initrd.img

102.6、生成镜像:

[root@m01 ~]# yum install mkisofs -y #安装镜像工具制作包;

[root@m01 CentOS6]# cd /application/CentOS6/

[root@m01 CentOS6]# mkisofs -o /application/CentOS-6.7-x86_64-lc.iso -b isolinux/isolinux.bin -c isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table -R -J -v -T .

# -o:制作的镜像文件名;

-b:指定在制作可开机光盘时所需的开机映像文件;

-c: 制作可开机光盘时,mkisofs会将开机映像文件中的全-eltorito-catalog<开机文件名称>全部内容作成一个文件;

-no-emul-boot:非模拟模式启动;

-boot-load-size 4: boot文件加载的大小;

-boot-info-table:生成boot列表;

-R:使用Rock Ridge Extensions;

-J:使用Joliet格式的目录与文件名称;

-v:显示详细的信息;

-T :建立文件名的转换表,适用于不支持Rock Ridge Extensions的系统上;

[root@m01 CentOS6]# ls -l /application/CentOS-6.7-x86_64-lc.iso

-rw-r--r-- 1 root root 671232000 12月 17 09:46 /application/CentOS-6.7-x86_64-lc.iso

102.6.1、植入md5校验码:

[root@m01 CentOS6]# cd /application/

[root@m01 application]# yum install isomd5sum -y #安装isomd5sum软件包;

[root@m01 application]# implantisomd5 CentOS-6.7-x86_64-lc.iso #在iso镜像包中植入md5校验码,只能植入一次;

Inserting md5sum into iso image...

md5 = 4a15e4800790a7d21001cef502457ea9

Inserting fragment md5sums into iso image...

fragmd5 = 5fa4ed4124f6b68b551fa9f8cd51987775fcd2da3a162fb658d889f91dde

frags = 20

Setting supported flag to 0

[root@m01 application]# checkisomd5 CentOS-6.7-x86_64-lc.iso

Press [Esc] to abort check.

The media check is complete, the result is: PASS.

It is OK to use this media.

102.7、安装制作的镜像包:

1、新建一台虚拟机,稍后安装操作系统;

2、启动虚拟机:

3、镜像主要信息:

最小化安装及额外选择4个包组及tree nmap sysstat lrzsz dos2unix这几个软件;

用户:root;密码:123456;主机名:CentOS6;

磁盘分区boot 200M swap 1G 剩余空间给/;

防火墙和selinux关闭;

上面定制的镜像仅仅包含系统,如果需要将我们的web服务或者mysql服务内嵌进镜像,将这些服务定制成rpm包,然后在102.3节收集rpm包这一步骤

将自己制作的rpm包放进/application/CentOS6/Packages目录,然后再改改第102.5节的ks.cfg文件即可。

如果想修改linux安装时的界面图片,这个图片的路径为isolinux/splash.jpg;

posted @ 2020-02-15 23:17  云起时。  阅读(527)  评论(0编辑  收藏  举报