首页 > 系统相关 >96、linux之rpm包定制

96、linux之rpm包定制

时间:2022-10-10 12:37:08浏览次数:64  
标签:-- root m01 nginx linux ruby rpm 96


96.1、rpm包定制介绍:

编译安装软件,优点是可以定制化安装目录、按需开启功能等,缺点是需要查找并实验出适合的编译参数,诸如MySQL之类的软件编译耗时过长。

yum安装软件,优点是全自动化安装,不需要为依赖问题发愁了,缺点是自主性太差,软件的功能、存放位置都已经固定好了,不易变更。

编译源码,根据自己的需求做成定制RPM包-->搭建内网yum仓库--yum安装。结合前两者的优点,暂未发现什么缺点。可能的缺点就是RPM包的通用性差,

只能适用于本公司的环境。另外一般人不会定制RPM包。这是中大型互联网企业运维自动化的必要技能。

96.2、安装rubygems软件可库;

[root@m01 ~]# yum -y install ruby rubygems ruby-devel

# 安装ruby模块和rubygems模块,fpm是ruby写的,因此系统环境需要ruby,

#rubygems是连接rubygems软件仓库的,类似于yum;

[root@m01 ~]# rpm -qa ruby#查看ruby的版本

ruby-1.8.7.374-5.el6.x86_64

[root@m01 ~]# gem sources --remove http://rubygems.org/ #删除原来的rubygems仓库

[root@m01 ~]# gem sources -a http://mirrors.aliyun.com/rubygems/ #添加aliyun的rubygems仓库

[root@m01 ~]# gem sources -l # 查看rubygems仓库

*** CURRENT SOURCES ***

​http://mirrors.aliyun.com/rubygems/ ​

[root@m01 ~]# gem install fpm #安装fpm,如果出现fpm无法安装,要求ruby特定的版本,则需要升级ruby;

[root@m01 ~]# fpm -v #查看fpm的版本

1.10.2

96.3、升级ruby软件:

(1)使用RVM进行升级ruby,在rvm官方网址:https://rvm.io/执行如下命令:

[root@m01 ~]#gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB

[root@m01 ~]#\curl -sSL https://get.rvm.io | bash -s stable

* To start using RVM you need to run `source /etc/profile.d/rvm.sh`

in all your open shell windows, in rare cases you need to reopen all shell windows.

[root@m01 ~]# source /etc/profile.d/rvm.sh #使脚本生效

[root@m01 ~]# rvm list known #查看RVM可安装的ruby的版本

[root@m01 ~]# rvm install 2.1 #安装ruby-2.1版本

[root@m01 ~]# ruby -v #查看ruby是否升级成功

[root@m01 ~]# ruby -v # 查看当前使用的ruby的版本

ruby 2.1.10p492 (2016-04-01 revision 54464) [x86_64-linux]

96.4、fpm工具打包详解:

FPM功能简单说就是将一种类型的包转换成另一种类型支持的源类型包;

支持源目标类型包:

dir #将目录打包成所需要的类型,可以用于源码编译安装的软件包

rpm #对rpm进行转换

gem #对rubygem包进行转换

python #将python模块打包成相应的类型

支持的目标类型包

rpm #转换为rpm包

deb #转换为deb包

solaris #转换为solaris包

puppet #转换为puppet模块

fpm常用参数:

-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

96.5、 安装nginx:

yum -y install pcre-devel openssl-devel

useradd nginx -M -s /sbin/nologin

tar xf nginx-1.8.1.tar.gz

cd nginx-1.8.1

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

make && make install

ln -s /application/nginx-1.8.1/ /application/nginx

96.6、编写脚本文件:

[root@m01 tools]# vim nginx_rpm.sh

#!/bin/bash

export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/rvm/bin:/root/bin

useradd nginx -M -s /sbin/nologin

ln -s /application/nginx-1.8.1/ /application/nginx

[root@m01 tools]# chmod u+x nginx_rpm.sh

96.5、对nginx打包:

[root@m01 application]# fpm -s dir -t rpm -n nginx -v 1.8.1 -d 'pcre-devel,openssl-devel' --post-install /root/tools/nginx_rpm.sh -f /application/nginx-1.8.1/

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

#/application/nginx-1.8.1/:代表要打包的目录,必须要“/”,同时也是rpm安装后的目录,后面可以跟多个;

[root@m01 application]# ls

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

[root@m01 application]# rpm -qp --scripts nginx-1.8.1-1.x86_64.rpm #查看安装包里的脚本文件

postinstall scriptlet (using /bin/sh):

#!/bin/bash

export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/rvm/bin:/root/bin

useradd nginx -M -s /sbin/nologin

ln -s /application/nginx-1.8.1/ /application/nginx

[root@m01 application]# rpm -qpl nginx-1.8.1-1.x86_64.rpm #查看rpm包中的所有文件

96.7、安装rpm包(其它机器上):

(1)rpm命令安装:

rpm -ivh nginx-1.8.1-1.x86_64.rpm #会报依赖错误,需要先yum安装依赖才能安装rpm包。

error: Failed dependencies:

pcre-devel is needed by nginx-1.6.2-1.x86_64

openssl-devel is needed by nginx-1.6.2-1.x86_64

(2)yum命令安装rpm包:

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

(3)搭建yum仓库:

97、配置yum源仓库服务器

96.8、fpm打包总结:

1、fpm类似tar打包一样,只是fpm打的包能够被yum命令识别而已 ;

2、fpm打包命令的最后一行参数代表要打包的目录,必须要“/”,同时也是rpm安装后的目录;

3、定制LNMP的RPM包思路:

编译安装好nginx,mysql,php,此处有个问题,就是php的大部分依赖环境是通过yum安装的,

但有一个libiconv-1.14.tar.gz包需要编译安装,安装时已经指定了安装目录,只需一同打包即可。还有一个问题,

就是mysql这个目录比较大,用fpm打包耗时长。平时我们有可能需要对nginx或php做优化,这样又得重新打包。

因此我们可以将mysql分离出来,分别打包。只需在制作nginx+php的rpm包时添加mysql的依赖即可。

(1)参考命令:

[root@web2 ~]# fpm -s dir -t rpm -n web2 -v 1.1 --description 'lnmp.cms,bbs.blog' -d 'libxslt-devel,nfs-utils,rpcbind,mysql,libmcrypt-devel,mhash,mhash-devel,mcrypt' \

--post-install /server/scripts/lnmp-init.sh /server/path

4、打包看似成功,但查看包的内容,只是这一个软链接文件:

原因:目录结尾的/问题,类似rm删除软链接目录(软连接一般不加/,如果加/会导致删除快捷文件时导致源文件夹被删除, 例如:ln -s /a b )



标签:--,root,m01,nginx,linux,ruby,rpm,96
From: https://blog.51cto.com/u_11409186/5743127

相关文章

  • Linux安装配置 jdk环境
    1、从官网上下载jdk的tar包​​https://www.oracle.com/java/technologies/javase/javase8u211-later-archive-downloads.html​​2、通过工具,将tar包传到Linux系统中,/usr/l......
  • linux基础命令
    systemctlget-default查看计算机系统启动后要进入的默认目标systemctlset-defaultmulti-user.target设置字符界面为默认目标超级用户root#其他用户$linux系统允......
  • Linux策略路由详解
    概述在Linux中,我们通常使用route 命令来做路由信息的管理。但是该命令仅仅只能用于基本路由信息的管理,面对功能更加强大的基于策略的路由机制,route 命令就显得捉襟见肘。......
  • linux网卡绑定bond
     1.什么是bond网卡bond是通过把多张网卡绑定为一个逻辑网卡,实现本地网卡的冗余,带宽扩容和负载均衡。在应用部署中是一种常用的技术。2.bond的模式种类常见的bond......
  • Linux策略路由详解
    概述在Linux中,我们通常使用route命令来做路由信息的管理。但是该命令仅仅只能用于基本路由信息的管理,面对功能更加强大的基于策略的路由机制,route命令就显得捉襟见肘。在......
  • CF963E Circles of Waiting(高斯消元,主元法)
    CF963ECirclesofWaiting平面直角坐标系上有一个点,开始在\((0,0)\),每秒钟这个点都会随机移动:如果它在\((x,y)\),下一秒它去\(4\)个方向的概率为\(p_0,p_1,p_2,......
  • 学会用Linux的帮助命令
    命令解释type[命令]判断是内部命令or外部命令--help外部命令help只针对系统内部命令man[]内容清晰、详细,在线文档,支持搜索(/name)man[......
  • 使用netdata 监控Linux 主机
    在linux主机上,直接使用下面的命令创建容器即可dockerrun-d--name=netdata\-p19999:19999\-vnetdataconfig:/etc/netdata\-vnetdatalib:/var/lib/netdat......
  • 给Linux的git添加清华镜像
    下载curlhttps://mirrors.tuna.tsinghua.edu.cn/git/git-repo-orepochmod+xrepo为了方便可以将其拷贝到你的PATH里。更新repo的运行过程中会尝试访问官方的git源......
  • linux 防火墙常用命令 - 备忘
    新增端口访问firewall-cmd--permanent--add-port=8080/tcp重启防火墙`systemctlrestartfirewalld.service其他关闭防火墙systemctlstopfirewalld.service......