[坑]打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时,表示更新一个包。

目录
相关文章
执行apt-get install xxx 遇到无法定位软件包解决方法
执行apt-get install xxx 遇到无法定位软件包解决方法
1737 0
执行apt-get install xxx 遇到无法定位软件包解决方法
|
2月前
|
PHP 数据格式
PHP 中的CURL 模拟表单的post提交
PHP 中的CURL 模拟表单的post提交
18 0
|
8月前
Cypress 等待某个 HTTP put 请求得到 200 状态码后,再执行下一步的操作代码
Cypress 等待某个 HTTP put 请求得到 200 状态码后,再执行下一步的操作代码
30 0
|
PHP 开发者
Composer update命令是干什么的?底层原理是什么?
Composer update命令是干什么的?底层原理是什么?
1823 0
|
安全
select_soft_post.php任意文件上传漏洞
select_soft_post.php任意文件上传漏洞
167 0
select_soft_post.php任意文件上传漏洞
|
网络协议
|
网络协议