IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:Spec文件

共 2 篇相关文章

IT 累计浏览 1,920

[坑]打rpm包时,注意%post和%postun的执行顺序

这篇讲的是RPM打包中一个容易被忽略的坑:升级软件包时,错误的脚本执行顺序会导致配置被意外修改。作者在打包PHP扩展时发现,每次执行`yum update`升级成功后,新扩展在php.ini中的配置项就会被自动注释掉。 问题出在spec文件的`%postun`段。升级时,系统会先执行新包的`%post`段(安装后),再执行旧包的`%postun`段(卸载后)。作者旧包的`%postun`脚本原本是为卸载准备的,会用sed注释掉扩展配置,这就在升级过程中被误触发了。 根本原因在于`%postun`段接收的参数:参数0代表卸载,1代表升级。解决方案很直接——在`%postun`脚本中增加判断,只有当参数为0时才执行注释操作。这样升级时配置就能完好保留。文章还清晰梳理了`%pre`、`%post`、`%preun`、`%postun`在不同场景(安装、升级、卸载)下接收的参数含义,对编写可靠的spec文件很有参考价值。

IT 累计浏览 3,434

RPM包的管理

这篇讲的是Linux世界里RPM包管理的那些事儿。文章从RPM(Red Hat Package Manager)这个Red Hat系发行版里的“老大哥”说起,它把软件预编译打包成标准格式,装起来是省心,但也被批评为不够灵活——你的系统环境得和打包时完全一致才行。 为了补上这块短板,SRPM(Source RPM)就登场了。它不光带源码,还贴心附上了依赖说明,安装时能自己检查缺啥。不过对于大多数用户,更常用的其实是YUM这个在线升级神器。它背后连着个服务器仓库,把所有软件和它们“谁依赖谁”的关系图都理得清清楚楚,一键安装就能自动摆平依赖链,和Debian系的apt-get解决的是同一类痛点。 文章后半段还聊了聊怎么自己动手打包RPM。核心工作是写好spec这个“配方文件”,软件叫啥、版本多少、安装时该跑什么命令都得写明白。至于找spec模板,优先级也说得很明白:先翻源码包,不行就找社区现成的改改,实在没有才自己从头写起。整个过程把RPM生态里打包分发的逻辑串了个七七八八。