RPM包定制

概述

问题:当领导给你 100 台已经安装好系统的服务器,然后让优化,让你提出一个快速部署方案。
解答:
  1.tar 打包 先编译安装 打包--》分发--》解包(比如 mysql 打包后直接就可以使用
  2.SaltStack,puppet
  3.定制 rpm yum 仓库 yum 安装
  4.openstack 虚拟机镜像和 docker 容器分发

回顾下安装软件的三种方式:
  1、编译安装软件,优点是可以定制化安装目录、按需开启功能等,缺点是需要查找并实验出适合的编译参数,诸如MySQL之类的软件编译耗时过长。
  2、yum安装软件,优点是全自动化安装,不需要为依赖问题发愁了,缺点是自主性太差,软件的功能、存放位置都已经固定好了,不易变更。===>如果你现在还为是使用编译安装软件还是使用yum安装软件发愁,那你就out了。
  3、编译源码,根据自己的需求做成定制RPM包–>搭建内网yum仓库–yum安装。结合前两者的优点,暂未发现什么缺点。可能的缺点就是RPM包的通用性差,只能适用于本公司的环境。另外一般人不会定制RPM包。这是中大型互联网企业运维自动化的必要技能。

一:YUM 安装
  优点:简单,便捷,解决源码包安装依赖问题,全自动化安装
  缺点:没有办法定制,需要网络,网络环境差的情况话,下载速度慢
二:编译安装
  优点:可以定制软件包(定制安装目录和软件功能),一定情况下不需要网络,可自由选择软件版本 
  缺点:安装过程慢,安装复杂,需要查找编译参数(对于一些编译错误,找人求助也讨人嫌),软件编译依赖性强
三:二进制安装
  优点:简单,快捷
  缺点:不能定制,包容量大(mysql 的二进制包 200M 左右)
四:定制 rpm 包 yum 仓库 yum 安装
  优点:可以根据自己的需求编译软件>>制作 rpm 包>>搭建 yum 仓库>>上传 rpm 包到 yum仓库>>客户端安装软件  
  缺点:第一步编译安装复杂,打包完成以后无法更改,一般人不会这个方法

 这里也不介绍rpm的概念,想了解的朋友可以查看http://www.ibm.com/developerworks/cn/linux/l-rpm/

rpmbuild 是 redhat 系统原生打包命令,这个命令的使用复杂不推荐使用此方法打包 rpm 包,太复杂啦,有想了解到的朋友可以参考:http://dreamway.blog.51cto.com/1281816/1110874或者自行百度,我们这里使用一个简单的FPM工具定制RPM包

FPM的安装与使用

主机环境:CentOS 6.5

FPM打包工具
  FPM的作者是jordansissel
  FPM的github:https://github.com/jordansissel/fpm
  FPM功能简单说就是将一种类型的包转换成另一种类型。

1. 支持的源类型包

dir         将目录打包成所需要的类型,可以用于源码编译安装的软件包
rpm         对rpm进行转换
gem         对rubygem包进行转换
python      将python模块打包成相应的类型

2. 支持的目标类型包

rpm         转换为rpm包
deb         转换为deb包
solaris     转换为solaris包
puppet      转换为puppet模块

3. FPM参数 (使用 fpm --help 查看更多帮助)

-s          指定源类型
-t          指定目标类型,即想要制作为什么包
-n          指定包的名字
-v          指定包的版本号
-C          指定打包的相对路径  Change directory to here before searching forfiles
-d          指定依赖于哪些包
-f          第二次打包时目录下如果有同名安装包存在,则覆盖它
-p          输出的安装包的目录,不想放在当前目录下就需要指定
--post-install      软件包安装完成之后所要运行的脚本;同--after-install
--pre-install       软件包安装完成之前所要运行的脚本;同--before-install
--post-uninstall    软件包卸载完成之后所要运行的脚本;同--after-remove
--pre-uninstall     软件包卸载完成之前所要运行的脚本;同--before-remove

 4.安装FPM工具

fpm 是 ruby 写的,因此系统环境需要 ruby,且 ruby 版本号大于 1.8.5。
# 安装 ruby 模块
yum -y install ruby ruby-devel rubygems
rpm -qa ruby rubygems ruby-devel
# 添加阿里云的 Rubygems 仓库,外国的源慢
gem sources -a http://mirrors.aliyun.com/rubygems/
gem sources  查看 Rubygems 仓库信息
# 移除原生的 Ruby 仓库
gem sources --remove http://rubygems.org/
# 安装 fpm
gem install fpm

***在安装ruby包时,可能无法使用yum的方式安装上rubygems包,只能下载rubygems的rpm包进行安装***

下载地址:http://rpmfind.net/linux/rpm2html/search.php?query=rubygems

rpm -ivh rubygems-1.3.7-5.el6.noarch.rpm  --nodeps  //这种方式安装会忽略runygems的依赖包,不建议使用
或者
yum -y localinstall rubygems-1.3.7-5.el6.noarch.rpm  //建议使用这种方式安装,它会先安装依赖包,再安装rubygems包,需要配置yum源

安装 fpm 打包工具时提示以下错误:

ERROR: Error installing fpm:
ruby-xz requires Ruby version >= 1.9.3.

 上面的提示表示您 Ruby 版本过低,需要安装 1.9.3 的版本,解决思路只需安装低版本的 fpm工具即可

 解决方法:

gem install json -v 1.8.3
gem install fpm -v 1.3.3
或者
gem install fpm    //先直接安装一次,再安装一个低版本的
gem install fpm -v 1.3.3

 案例:Nginx服务定制RPM

1. 编译安装Nginx服务

yum -y install pcre-devel openssl-devel            //安装Nginx依赖包
useradd -M -s /sbin/nologin nginx            //添加Nginx运行用户
tar zxvf nginx-1.8.1.tar.gz -C /usr/src/        //编译安装Nginx
cd /usr/src/nginx-1.8.1/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_stub_status_module
make && make install
ln -s /usr/local/nginx/sbin/* /usr/local/sbin/        //优化Nginx程序执行路径
nginx                //启动Nginx服务,并验证

2.开始定制Nginx服务的RPM包

(1)停止Nginx服务

[root@aery ~]# lsof -i :80
 COMMAND  PID  USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
 nginx   8439  root    6u  IPv4  38775      0t0  TCP *:http (LISTEN)
 nginx   8440 nginx    6u  IPv4  38775      0t0  TCP *:http (LISTEN)
[root@aery ~]# killall -9 nginx
[root@aery ~]# lsof -i :80

(2)编写脚本,用来 nginx 打包完成后,安装后自动执行的脚本

[root@aery ~]# mkdir -p /server/scripts
[root@aery ~]# vim /server/scripts/nginx.sh
 #!/bin/bash
 useradd -M -s /sbin/nologin nginx
 ln -s /usr/local/nginx/sbin/* /usr/local/sbin/

(3)将 nginx 服务打包成 rpm 包,并指定需要安装的依赖包

[root@aery ~]# fpm -s dir -t rpm -n nginx -v 1.8.1 -d 'pcre-devel,openssl-devel' --post-install /server/scripts/nginx.sh -f /usr/local/nginx/
 no value for epoch is set, defaulting to nil {:level=>:warn}
 no value for epoch is set, defaulting to nil {:level=>:warn}
 Created package {:path=>"nginx-1.8.1-1.x86_64.rpm"}

(4)将打包完成的 rpm 包下载下来,上传到需要安装的服务器上即可实现 yum 安装,或者是上传到 yum 仓库中提供给 yum 客户端安装

安装 RPM包的三种方法

1) rpm命令安装

[root@aery ~]# rpm -ivh nginx-1.8.1-1.x86_64.rpm 
error: Failed dependencies:
    pcre-devel is needed by nginx-1.8.1-1.x86_64

但会报如上依赖错误,需要先 yum 安装依赖才能安装 rpm 包

2) yum命令安装

yum -y localinstall nginx-1.8.1-1.x86_64.rpm

这个命令会自动先安装 rpm 包的依赖,然后再安装 rpm 包。

3)我们可以将打包完成的 rpm 上传 YUM 仓库。然后进行 yum 安装即可

YUM仓库搭建参考:http://www.cnblogs.com/zhichaoma/p/7581957.html

#服务端
[root@aery ~]# cp nginx-1.8.1-1.x86_64.rpm /yum_source/   //将nginx的rpm包放到yum仓库中
[root@aery ~]# createrepo --update /yum_source/      //更新域名仓库

#客户端
[root@aery ~]# yum clean all            //清除 yum 以前的缓存
[root@aery ~]# yum makecache            //更新 YUM 缓存
[root@aery ~]# yum list | grep nginx        //检查是否可以从yum源中找到Nginx的rpm包
nginx.x86_64                           1.8.1-1                           @inside
[root@aery ~]# yum -y install nginx        //安装Nginx
[root@aery ~]# nginx                 //启动Nginx服务
[root@aery ~]# lsof -i :80            //检查 Nginx服务是否启动
COMMAND  PID  USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
nginx   3900  root    6u  IPv4  29101      0t0  TCP *:http (LISTEN)
nginx   3901 nginx    6u  IPv4  29101      0t0  TCP *:http (LISTEN)

最后使用客户机验证客户机的服务是否可以访问(关闭客户机的iptables)

对mysql数据库进行定制RPM时的思路是,不要初始化数据库

RPM常用命令组合

man rpm #查看 rpm 帮助
rpm -qpi nginx-1.6.3-1.x86_64.rpm #查看 rpm 包信息
rpm -qpl nginx-1.6.3-1.x86_64.rpm #查看 rpm 包内容
rpm -qpR nginx-1.6.3-1.x86_64.rpm #查看 rpm 包的依赖
rpm -qp --scripts nginx-1.6.3-1.x86_64.rpm #查看 rpm 包带的执行脚本,执行脚
本以文件形式存在 rpm 包中
rpm -ivh nginx-1.6.3-1.x86_64.rpm #安装 rpm 包
rpm -ivh --aid *.rpm #--aid 参数解决 rpm 包
循环依赖的问题,即当前目录有所有相互依赖的 rpm 包,就可以用这种方法。
rpm -Uvh *.rpm #如果依赖版本有更新的则自动更新
yum localinstall *.rpm #自动安装 rpm 的依赖包

 

posted @ 2017-09-23 18:48  ZhiChao&  阅读(635)  评论(0编辑  收藏  举报