首页 » 开源分析 » [坑]打rpm包时,注意%post和%postun的执行顺序

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

 

问题

掉进坑里面了。最近完成了阿里PHP5.5.25的rpm打包。今天在升级其中一个扩展的时候发现,只要升级成功之后,扩展在配置文件中相关配置项就会被注释掉。最终定位到是spec文件中%postun段写的有问题。
spec文件中%postun段的代码示例如下:

%postun
conf_path="/php-fpm/lib/php.ini"
sed -i 's/^\[tclip\]/;\[tclip\]/g' $conf_path
sed -i 's/^extension=tclip.so/;extension=tclip.so/g' $conf_path

代码的作用就是,当删除PHP扩展rpm包的时候,会自动修改配置文件,注释掉扩展配置项。

原因

为啥在执行yum update 命令时,会导致扩展的配置项被自动注释掉呢?原因就在于spec执行顺序。
假如你升级前的php-tclip包的版本是1.0。升级后的php-tclip包的版本是2.0。
当你执行yum update php-tclip -y 命令升级时,%post和%postun段的执行顺序如下:
首先,执行新的2.0包spec文件中的%post段代码。
然后,执行旧的1.0包spec文件中的%postun段代码。

当升级时,完整的执行流程如下:
1、执行新包spec文件中 %pre 段.
2、安装新包的相关依赖包.
3、执行新包spec文件中的 %post 段.
4、执行旧包spec文件中的 %preun 段.
5、删除新包中不需要的旧文件。
6、执行旧包spec文件中的 %postun 段.

解决方案

其实不同的操作,会传不同的参数给 %postun段。当,传给%postun段的第一个参数是0时,代表卸载。我们的本意只有在卸载的时候,才需要执行%postun段的代码,自动注释php.ini的相关选项。我们只要增加判断就可以了。代码如下:

%postun
if [ "$1" = "0" ] ; then
conf_path="/php-fpm/lib/php.ini"
sed -i 's/^\[tclip\]/;\[tclip\]/g' $conf_path
sed -i 's/^extension=tclip.so/;extension=tclip.so/g' $conf_path
fi

完整的参数传递如下:

%pre和%post段

当传递的第一个参数为1时,表示新安装一个rpm包。
当传递的第一个参数为2时,表示升级一个已经存在的包。

%preun和%postun段

当传递的第一个参数为0时,表示删除一个包。
当传递的第一个参数为1时,表示更新一个包。

参考文档

Packaging software with RPM, Part 2: Upgrading and uninstalling software

技术交流

原文链接:[坑]打rpm包时,注意%post和%postun的执行顺序,转载请注明来源!

原文链接:[坑]打rpm包时,注意%post和%postun的执行顺序,转载请注明来源!

9