构建本地yum源之rpmbuild
组内准备搭建内部yum源,在这之前需要规范软件的安装目录,并把现有的应用打包。
目前接触两种rpm打包工具,rpmbuild和fpm。
- rpmbuild
rpmbuild关键是spec文件编写。
环境搭建
yum -y install rpm-build rpmdevtools
useradd rpm; su rpm
注: rpm打包需要特定目录下,在近期版本下rpmbuild可以在非root账号家目录下创建打包目录:
rpmdev-setuptree
[rpm@vm-1-lz rpmbuild]$ ll
total 20
drwxrwxr-x. 2 rpm rpm 4096 Dec 22 14:46 BUILD
drwxrwxr-x. 2 rpm rpm 4096 Dec 22 14:46 RPMS
drwxrwxr-x. 2 rpm rpm 4096 Dec 22 15:06 SOURCES
drwxrwxr-x. 2 rpm rpm 4096 Dec 22 16:07 SPECS
drwxrwxr-x. 2 rpm rpm 4096 Dec 22 14:46 SRPMS
[rpm@vm-1-lz rpmbuild]$
注:这里是/home/rpm/rpmbuild, 这个默认目录可以修改,可以修改宏定义:
/usr/lib/rpm/macros:
_topdir %{getenv:HOME}/rpmbuild
然后在rpmbuild/SPECS 目录下创建spec文件:
cd ~/rpmbuild/SPECS
rpmdev-newspec -o example.spec
SPEC文件
打包过程是
1. %prep 解压source部分定义的压缩包到 %build目录下
注:Source需要是tar格式压缩文件,这样setup才能调用 (source 跟setup可以多条记录,并依序对应)
2 %build 可以调用%configure宏变量或是直接调用configure命令直接配置
3 %install 安装文件到%buildroot下 (rpmbuild/BUILDROOT), 在这部分,需要确保目录已经存在不然会报错,比如拷贝配置文件到/etc/下,需要建立%buildroot/etc 目录
注:%install 部分是用绝对路径的,所以最好引用%buildroot
4 %file 部分定义那些文件将被打包进rpm包里
注:%file部分是用相对路径,我们可以用宏变量 比如%_prefix 代表/usr 其绝对路径就是%buildroot/usr
参考 http://fedoraproject.org/wiki/Packaging:RPMMacros
- fpm 打包
这是一个开源的项目 https://github.com/jordansissel/fpm
环境搭建:
yum -y ruby ruby-devel rubygems rpm-build
gem install fpm
注: 这里有个坑。如果正常按照gem去安装 我们是没办法调用 fpm成功的,因为 cabin的版本有问题:
[root@vm-1-lz RPMS]# fpm
/usr/lib/ruby/gems/1.8/gems/cabin-0.8.0/lib/cabin/mixins/logger.rb:12:in `included': undefined method `options' for #<Cabin::Subscriber:0x7fad75e31b90> (NoMethodError)
from /usr/lib/ruby/gems/1.8/gems/cabin-0.8.0/lib/cabin/channel.rb:105:in `call'
....
因此, 卸载当前cabin版本:
gem uninstall cabin
....
gem install cabin -v 0.7.2
用前一个版本的cabin才能正确启动fpm
构建rpm包
把之前编译好的nginx打包:
nginx 目录: /usr/local/nginx
fpm命令:
fpm -e -s dir -t rpm -n nginx -v 1.8.0 -C /usr/local/nginx --prefix=/opt/nginx
注: -e 可以让我们看到具体的spec文件, 如果没问题,保存退出就能在当前目录创建一个rpm包
但是fpm不能友好的按照规范路径打包
- SPEC例子
Name: tengine
Version: 1.5.
Release: %{?dist}
Summary: tengine-1.5. Group: Application/System
License: GPL
URL: http://tengine.taobao.org/
Source0: tengine-1.5..tar.gz
Source1: LuaJIT-2.0..tar.gz
Source2: pcre-8.34.tar.gz
Source3: openssl-1.0.2e.tar.gz
Source4: zlib-1.2..tar.gz
Source5: ngx_devel_kit-0.2..tar.gz
Source6: jemalloc-3.4..tar.bz2
Source7: nginx-bb-1.8..tar.gz Requires: zlib,pcre,openssl,LuaJIT %description
tengine-1.5. %prep
%setup -b
%setup -b
%setup -b
%setup -b
%setup -b
%setup -b
%setup -b
%setup -b %build
CFLAGS="${CFLAGS:--O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic}" ; export CFLAGS ;
CXXFLAGS="${CXXFLAGS:--O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic}" ; export CXXFLAGS ;
FFLAGS="${FFLAGS:--O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -I/usr/lib64/gfortran/modules}" ; export FFLAGS ;
./configure \
--with-http_ssl_module \
--prefix=/opt/nginx \
--error-log-path=/opt/nginx/logs/ \
--http-log-path=/opt/nginx/logs/ \
--pid-path=/opt/nginx/run/ \
--lock-path=/opt/nginx/lock/ \
--user=www \
--group=www \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--with-http_lua_module \
--with-luajit-inc=/usr/local/include/luajit-2.0 \
--with-luajit-lib=/usr/local/lib \
--with-pcre=%{_builddir}/pcre-8.34 \
--with-openssl=%{_builddir}/openssl-1.0.2e \
--with-zlib=%{_builddir}/zlib-1.2. \
--with-http_concat_module \
--with-http_sysguard_module \
--with-http_realip_module \
--without-syslog \
--with-jemalloc \
--add-module=%{_builddir}/ngx_devel_kit-0.2. make %{?_smp_mflags} %install
rm -rf $RPM_BUILD_ROOT make install DESTDIR=$RPM_BUILD_ROOT mv %{buildroot}/opt/nginx/conf %{buildroot}/opt/nginx/conf.default
install -d %{buildroot}/opt/nginx/conf
cp -r %{_builddir}/nginx-bb-1.8./conf/* %{buildroot}/opt/nginx/conf %clean
rm -rf $RPM_BUILD_ROOT %files
%defattr(-,root,root,-)
%doc
/opt/nginx/* %changelog
构建本地yum源之rpmbuild的更多相关文章
- 构建本地yum源之rpmbuild问题汇总
- check-rpaths的问题 今天在编译varnish的时候,遇到几个问题,其中一个就是出现如下错误: ...+ /usr/lib/rpm/check-rpaths /usr/lib/rpm/c ...
- 本地yum源构建以及Docker离线安装
Docker离线安装以及本地yum源构建 在docker的使用过程中有时候会遇到一些私有化部署的问题,就是在一些无法上网的机器上面安装使用dokcer,这就引出了docker的离线安装的问题,dock ...
- Linux虚拟机配置本地yum源
刚开始使用Linux,自己构建了一个Linux虚拟机之后,在使用yum install的时候,经常是出错,提示连接不上. 一直以为是自己构建的虚拟机的问题,后来在网上查找了一些资料,才发现:需要配置本 ...
- CentOS7利用本地yum源配置NBD
一:CentOS7.0创建本地YUM源 (物理机:直接将刻录的CentOS7光盘利用光驱插入物理机上) (虚拟机: CD/DVD>>连接本地ISO) 针对物理机192.168.9.112进 ...
- 部署企业本地yum源及源码包安装
YUM命令 yum list //列出每个软件包(包括未安装和已安装) rpm -q repolist //列出所以仓库名称 info //查看软件信息 rpm -qi install //安装 rp ...
- centos本地yum源安装
1.为DVD或U盘创建一个用于挂载的目录 [root@localhost ~]# mkdir /media/CentOS/ 2.查看DVD或U盘所在的路径 [root@localhost ~]# fd ...
- redhat 配置本地yum源163yum源epel 源,无需卸载yum!无须拷贝ISO,愿网上少一点垃圾教程误人子弟
都知道redhat不收费,但是其yum服务是要收费的,不想出钱那就自己配置yum源就好了. 首先,博主之前也没用过redhat,第一次用yum装包的时候提示什么没注册之类的,balaba一大堆,然后就 ...
- RedHat Linux RHEL6配置本地YUM源
YUM是Yellow dog Updater Modified的简称,起初是由yellow dog这一发行版的开发者Terra Soft研发,用python写成,那时还叫做yup(yellow dog ...
- RHEL7.2和RHEL6.5的配置网络yum源和本地yum源
RHEL7.2配置本地yum源 [root@localhost ~]#monut /dev/sr0 /mnt #挂载光盘 [root@localhost ~]# rm -rf /etc/yu ...
随机推荐
- linux c/c++ GDB教程详解(转)
http://www.gnu.org/manual/ http://www.gnu.org/software/gdb/documentation/ http://sourceware.org/gdb/ ...
- Linux中的syslog 入门学习教程
syslog是linux系统中默认的日志守护进程,默认的syslog配置文件是/etc/syslog.conf文件.程序.守护进程和内核提供了访问系统的日志信息.任何希望生成日志信息的程序都可以向sy ...
- LightOJ 1236 Pairs Forming LCM 合数分解
题意:求所有小于等于n的,x,y&&lcm(x,y)==n的个数 分析:因为n是最小公倍数,所以x,y都是n的因子,而且满足这样的因子必须保证互质,由于n=1e14,所以最多大概在2^ ...
- codeforces 652D Nested Segments 离散化+树状数组
题意:给你若干个区间,询问每个区间包含几个其它区间 分析:区间范围比较大,然后离散化,按右端点排序,每次更新树状数组中的区间左端点,查询区间和 注:(都是套路) #include<cstdio& ...
- Microsoft SQL Server,错误:2;SQL Server配置管理器(本地)—远程过程调用失败
本机是先安装sqlserver2008,后安装vs2012 在安装sqlserver2008后,运行sqlserver2008正常,接着安装vs2012,再运行sqlserver2008,问题出现了, ...
- Unity3d Physically Based Hair Shading in Unreal
---by wolf96 16/10/16
- 安装solr
安装之前先关闭防火墙.安装好jdk和tomcat 1.启动tomcat的命令为:apache-tomcat-7.0.61/bin/startup.sh 2.拷贝solr目录下example/webap ...
- The Shortest Path in Nya Graph
Problem Description This is a very easy problem, your task is just calculate el camino mas corto en ...
- 【原】Spark Standalone如何通过start-all.sh启动集群
1.start-all.sh脚本分析 图1 start-all.sh部分内容 我们可以从start-all.sh脚本源文件中看到它其实是start-master.sh和start-slaves.sh两 ...
- ARFF文件格式
Attribute -Relation File Format (ARFF) 此文档翻译自http://www.cs.waikato.ac.nz/~ml/weka/arff.html.文档写的比较粗糙 ...