自动化部署必备技能—定制化RPM包

回顾下安装软件的三种方式:

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

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

这里也不介绍rpmbuild这个打包工具了,想了解的朋友自行谷歌百度。但我不建议大家花太多的时间去学习这个命令,比较晦涩,而且我会在下面介绍更简单的命令。

FPM打包工具

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

1. 支持的源类型包

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

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

</pre>

2. 支持的目标类型包

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. rpm 转换为rpm包
  2. deb 转换为deb包
  3. solaris 转换为solaris包
  4. puppet 转换为puppet模块

</pre>

3. FPM安装

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. fpm是ruby写的,因此系统环境需要ruby,且ruby版本号大于1.8.5。
  2. # 安装ruby模块
  3. yum -y install ruby rubygems ruby-devel
  4. # 查看当前使用的rubygems仓库
  5. gem sources list
  6. # 添加淘宝的Rubygems仓库,外国的源慢,移除原生的Ruby仓库
  7. gem sources --add https://ruby.taobao.org/ --remove http://rubygems.org/
  8. # 安装fpm,gem从rubygem仓库安装软件类似yum从yum仓库安装软件。首先安装低版本的json,高版本的json需要ruby2.0以上,然后安装低版本的fpm,够用。
  9. gem install json -v 1.8.3
  10. gem install fpm -v 1.3.3
  11. # 上面的2步安装仅适合CentOS6系统,CentOS7系统一步搞定,即gem install fpm

</pre>

4. FPM参数

详细使用见fpm –help

常用参数

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

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

</pre>

使用实例–实战定制nginx的RPM包

1. 安装nginx

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. yum -y install pcre-devel openssl-devel

  2. useradd nginx -M -s /sbin/nologin

  3. tar xf nginx-1.6.2.tar.gz

  4. cd nginx-1.6.2

  5. ./configure --prefix=/application/nginx-1.6.2 --user=nginx --group=nginx --with-http_ssl_module --with-http_stub_status_module

  6. make && make install

  7. ln -s /application/nginx-1.6.2/ /application/nginx

</pre>

2. 编写脚本

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. [root@oldboy ~]# cd /server/scripts/

  2. [root@oldboy scripts]# vim nginx_rpm.sh # 这是安装完rpm包要执行的脚本

  3. #!/bin/bash

  4. useradd nginx -M -s /sbin/nologin

  5. ln -s /application/nginx-1.6.2/ /application/nginx

</pre>

3. 打包

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. [root@oldboy ~]# fpm -s dir -t rpm -n nginx -v 1.6.2 -d 'pcre-devel,openssl-devel' --post-install /server/scripts/nginx_rpm.sh -f /application/nginx-1.6.2/
  2. no value for epoch is set, defaulting to nil {:level=>:warn}
  3. no value for epoch is set, defaulting to nil {:level=>:warn}
  4. Created package {:path=>"nginx-1.6.2-1.x86_64.rpm"}
  5. [root@oldboy ~]# ll -h nginx-1.6.2-1.x86_64.rpm
  6. -rw-r--r-- 1 root root 6.7M Nov 1 10:02 nginx-1.6.2-1.x86_64.rpm

</pre>

4. 安装rpm包

安装rpm包的三种方法:

  • rpm命令安装

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. [root@LB-nginx-01 ~]# rpm -ivh nginx-1.6.2-1.x86_64.rpm
  2. error: Failed dependencies:
  3. pcre-devel is needed by nginx-1.6.2-1.x86_64
  4. openssl-devel is needed by nginx-1.6.2-1.x86_64
  5. 但会报如上依赖错误,需要先yum安装依赖才能安装rpm包。

</pre>

  • yum命令安装rpm包

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. yum -y localinstall nginx-1.6.2-1.x86_64.rpm
  2. 这个命令会自动先安装rpm包的依赖,然后再安装rpm包。

</pre>

注意事项

1. 相对路径问题

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. # 相对路径
  2. [root@oldboy nginx]# fpm -s dir -t rpm -n nginx -v 1.6.2 .
  3. no value for epoch is set, defaulting to nil {:level=>:warn}
  4. no value for epoch is set, defaulting to nil {:level=>:warn}
  5. Created package {:path=>"nginx-1.6.2-1.x86_64.rpm"}
  6. [root@oldboy nginx]# rpm -qpl nginx-1.6.2-1.x86_64.rpm
  7. /client_body_temp
  8. /conf/extra/dynamic_pools
  9. /conf/extra/static_pools
  10. …………
  11. # 绝对路径
  12. [root@oldboy ~]# fpm -s dir -t rpm -n nginx -v 1.6.2 /application/nginx-1.6.2/
  13. no value for epoch is set, defaulting to nil {:level=>:warn}
  14. no value for epoch is set, defaulting to nil {:level=>:warn}
  15. Created package {:path=>"nginx-1.6.2-1.x86_64.rpm"}
  16. [root@oldboy ~]# rpm -qpl nginx-1.6.2-1.x86_64.rpm
  17. /application/nginx-1.6.2/client_body_temp
  18. /application/nginx-1.6.2/conf/extra/dynamic_pools
  19. /application/nginx-1.6.2/conf/extra/static_pools
  20. /application/nginx-1.6.2/conf/fastcgi.conf
  21. /application/nginx-1.6.2/conf/fastcgi.conf.default
  22. …………
  23. 使用rpm -qpl 命令可以查看rpm包的内容。
  24. 注:fpm类似tar打包一样,只是fpm打的包能够被yum命令识别而已。

</pre>

2. 软链接问题

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. [root@oldboy ~]# fpm -s dir -t rpm -n nginx -v 1.6.2 /application/nginx

  2. no value for epoch is set, defaulting to nil {:level=>:warn}

  3. File already exists, refusing to continue: nginx-1.6.2-1.x86_64.rpm {:level=>:fatal}

  4. # 报错是因为当前目录存在同名的rpm包,可以使用-f参数强制覆盖。

  5. [root@oldboy ~]# fpm -s dir -t rpm -n nginx -v 1.6.2 -f /application/nginx

  6. no value for epoch is set, defaulting to nil {:level=>:warn}

  7. Force flag given. Overwriting package at nginx-1.6.2-1.x86_64.rpm {:level=>:warn}

  8. no value for epoch is set, defaulting to nil {:level=>:warn}

  9. Created package {:path=>"nginx-1.6.2-1.x86_64.rpm"}

  10. 打包看似成功,但查看包的内容,只是这一个软链接文件。

  11. [root@oldboy ~]# rpm -qpl nginx-1.6.2-1.x86_64.rpm

  12. /application/nginx

  13. 原因:目录结尾的/问题,类似rm删除软链接目录

</pre>

定制LNMP的RPM包思路

编译安装好nginx,mysql,php,此处有个问题,就是php的大部分依赖环境是通过yum安装的,但有一个libiconv-1.14.tar.gz包需要编译安装,安装时已经指定了安装目录,只需一同打包即可。

还有一个问题,就是mysql这个目录比较大,用fpm打包耗时长。平时我们有可能需要对nginx或php做优化,这样又得重新打包。因此我们可以将mysql分离出来,分别打包。只需在制作nginx+php的rpm包时添加mysql的依赖即可。

<pre class="prettyprint linenums prettyprinted" style="box-sizing: border-box; overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; display: block; padding: 9.5px; margin: 0px 0px 10px; line-height: 1.42857; word-break: break-all; overflow-wrap: break-word; color: rgb(51, 51, 51); background-color: rgb(245, 245, 245); border: 1px solid rgb(204, 204, 204); border-radius: 4px;">

  1. # 参考命令
  2. [root@web2 ~]# fpm -s dir -t rpm -n web2 -v 1.1 \
  3. --description 'lnmp.cms,bbs.blog' \
  4. -d ‘libxslt-devel,nfs-utils,rpcbind,mysql,libmcrypt-devel,mhash,mhash-devel,mcrypt' \
  5. --post-install /server/scripts/lnmp-init.sh \
  6. /application /usr/local/libiconv/ /app/logs/ /data0/ /server/

</pre>

本文转载于张耀的博客,原文链接

来自为知笔记(Wiz)

AD:****官方群:运维交流09群385168604 Linux交流QQ群339128815

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355

推荐阅读更多精彩内容