Version 1 (modified by yasumichi, 11 years ago) (diff) |
---|
Vine Linux ドキュメント / RPM パッケージの作成方法 / シンボリック・リンク等を %post とかで張らない
シンボリック・リンクを含む全てのファイルを %install まででインストールして、 %files に加えるべきである。
これは特に重要です。よく、%post で、シンボリック・リンクをはって、 %preun でそのリンクを削除するような SPEC ファイルがあります。 これを行うと、アップデート時に問題が生じることがあります。以前、 libc のパッケージでこういう記述が入ってるものがあって、深刻な問題が生じたこともありました。
その理由は、rpm -U <new-rpm> としたときに、
rpm -e <old-rpm> rpm -i <new-rpm>
ではなく、
rpm -i <new-rpm> rpm -e <old-rpm>
とはたらくためです。
つまり、%post で、シンボリック・リンクをはって、 %preun でそれを削除するような rpm のバージョンアップをしようと、 rpm -U (アップデート)を実行すると
この仕様は、libc とかのアップグレードの途中で libc とかがなくなってトラブルが生じるのを避けようとしたためのものと思われます。
実はこの問題は解決法があります。 %pre, %post, %preun, %postun のスクリプト実行時には、スクリプトに対して以下の引数が与えられます。
すなわち、はじめてインストールするときには、引数として 1 がわたされ、 rpm -e でアンインストールするときには 0 がわたされるわけです。 これを利用すると、
%post if [ $1 = 1]; then echo ``First installation!'' fi %preun if [ $1 = 0]; then echo ``Good bye!'' fi
とかできるわけです。(それでも %post などでシンボリック・リンクをはったりすると、出どころ不明のファイルが増えることになります。その他トラブルをさけるため、できるだけファイルは %files に加えるようにし、 %post などに書くスクリプトはできるだけ少なくしましょう)