rpmbuild 解惑

有些事情我们不知道该怎么办, 但其实我们根本不知道自己在做什么

rpm 是什么?

rpm 是一种"包"的格式. 其中大致包含两类数据:

  • 元数据: 主要是 tag, 例如:

    • Name: 软件包的名称,后面可使用%{name}的方式引用
    • Summary: 软件包的内容概要
    • Version: 软件的实际版本号,例如:1.0.1等,后面可使用%{version}引用
    • Release: 发布序列号,例如:1linuxing等,标明第几次打包,后面可使用%{release}引用
    • Group: 软件分组,建议使用标准分组
    • License: 软件授权方式,通常就是GPL
    • Source: 源代码包,可以带多个用Source1、Source2等源,后面也可以用%{source1}、%{source2}引用
    • BuildRoot: 这个是安装或编译时使用的“虚拟目录”

    元数据, 一部分是给人看的, 让他们了解将要安装的包都包含什么. 还有一部分是给包管理系统(yum)看的, 例如: 包的依赖关系.

  • 文件数据

    包含最终安装都系统上的文件, 以及文件的属性, 属主等信息.

    我们将软件打成 rpm 的目的, 是要在系统上安装该软件. 所以, 我们应该在 rpm 包里放什么呢? 这取决于你想在系统上安装什么? 这完全由打包者决定. 通常一个软件会包含: 可执行文件, 配置文件, 文档等. 但是, 如果你只想打包一些 html 页面呢?. 也 ok 啊.

我们见过不少包管理系统, 以及包的格式, 例如: yum & rpm, apt & deb, rubygem & gem, python pip & pip 等等. 不同的包管理系统和包的格式并没什么本质区别.

编译?

我们知道要将源码放到 SOURCES 目录, 文件名可能是 abc-1.1.1.tar.gz, 但是 rpmbuild 是怎么把源码最终变成 rpm 包的呢?

  1. 将源码文件解压到 BUILD 目录, 目录可能是叫 abc-1.1.1. 通常源码包解压出来的目录名称和源码包的名字是对应的, 但是总有不一致的情况, 尤其是一些私有软件, 打包源码时往往不是很规范, 甚至连版本号都没有. %setup 可以用来指定将源码解压到什么目录:

    • %setup 不加任何选项,仅将软件包打开。
    • %setup -n newdir 将软件包解压在newdir目录。
    • %setup -c 解压缩之前先产生目录。

    这里列的只是一部分参数, 这些参数其实不重要, 因为你在手册上都能查到.

    后面的步骤都会在解压出来的源码目录进行.

    后面的步骤都会在解压出来的源码目录进行.

    后面的步骤都会在解压出来的源码目录进行.

  2. 在解压出来的源码目录进行编译.

    当然, 有些软件不需要编译, 或者你已经编译好了(你完全可以把编译好的程序打成 tag.gz 丢到 SOURCES 目录, spec 中就不需要定义编译相关的内容了. 就跟打包一堆 html 没什么区别).

    %build 定义了如何编译你的软件, make 也好, maven 也好, 如果不需要编译, 那就空着就好了. 项目原本怎么编译, 把相应的命令贴到 %build 就好了, 并没有什么区别. 如果打包失败是因为编译不通过, 那对不起, 这个锅 rpmbuild 不会背.

    编译的环境就是系统环境, 不存在一个隔离的"编译环境", 所以, 如果缺 lib, 缺头文件, 在系统上安装就好了.

    rpmbuild 只是替你"敲"了那些编译命令而已, 和你自己敲没什么区别.

  3. "安装"

    编译过 c/c++ 项目的同学知道, 编译(make) 完成后, 通常需要安装(make install). 将编译的结果部署到系统的某个或者某几个目录.

    rpm 打包过程也包含安装(%install)这一步, 但并不是"真"的安装到系统的某个目录. 而是安装到以 %{RPM_BUILD_ROOT} 为根的路径下.

    例如, 你有一个文件 abc, 希望最终部署到系统的 /usr/local/bin/ 下, 那么 %install 阶段, 我们应该把它安装到 %{RPM_BUILD_ROOT}/usr/local/bin/ 下. 也就是以 %{RPM_BUILD_ROOT} 为根的绝对路径.

    为什么要这么干呢? 目的是为了构建 rpm 包内的目录结构, 方便后续的打包工作.

  4. 打包

    把元数据 和 %{RPM_BUILD_ROOT} 按照一定的格式打包在一起就是最终的 rpm 包了. 会存放在 RPMS 目录下.

    有了按照系统路径构建的 %{RPM_BUILD_ROOT}, 打包或者安装阶段就不用关心一个文件在最终 rpm包 安装的时候应该放在什么路径了-- 包里在什么路径, 就安装到什么路径.

  5. 安装

    将 rpm 包拷贝到目标机器, 或者加入到目标机器可以访问到的本地 yum 仓库后. 就可以在目标机器上安装了.

    rpm 会将包里的文件按照其路径, 放到系统的对应位置. 感觉上就好像你在根目录解压一个 zip 包一样. 包里的文件"自动"找到了自己的位置.

    yum 除了拷贝文件外, 还会检查元数据里定义的依赖, 以便将依赖项也一起安装. 解决包依赖, 也是 yum 最主要的任务.

总结

所以, 回头看看, 什么是 rpm 呢? rpm包和一个附加了一点元数据的 zip包有什么区别呢?

rpm 如何构建呢? 我们通过 spec 在一个临时目录(%{RPM_BUILD_ROOT})构建了一个目录树, 同时声明了一些元数据, 然后 rpmbuild 把目录树和元数据打成一个包, 就成了 rpm.

spec 中那些宏总是让我们很费解, 但是考虑到 rpm包 被发明的时间, 你如果有一点 C/C++ 的背景理解起来可能会容易一些, rpm 已经是一个比很多工程师年龄都大的"长辈"了.

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