Downgrading Packages (日本語)

From ArchWiki
Jump to: navigation, search
概要
パッケージのバージョンを戻す意味と方法。
関連記事
Arch Build System (日本語)
pacman (日本語)
ARM

ここではパッケージを前のバージョンにダウングレードする方法を記述します。パッケージのダウングレードは普段は推奨されていませんが、最新パッケージにバグがあるときに必要になります。

ダウングレードする前に、なぜそうするのか考えて下さい。バグが理由ならば、Arch やそのプログラムの開発者にバグトラッカーでバグを報告するのに少し時間をさくことを考えていただけるでしょうか。Arch はローリングリリースなので、新しいパッケージにひそんだバグに出くわす可能性がいつでもあります。

私達やアップストリームの開発者は利用者からの報告にいつも感謝しています。ほんのすこしの情報でも、テストやデバッグに必要な時間を少なくし、ソフトウェアを安定させるのに役だっているのです。

Contents

理由

ダウングレードするということは現在のパッケージをアンインストールして前のバージョンをインストールすることです。その前のバージョンというのが一つ前のバージョン(パッケージのバージョンは一つ前です)なのか、かなり前のバージョンなのかは分かりません。

ダウングレードする理由で(数ある中でも)挙げられるのは: 現在のバージョンにバグがある・期待どおりに働かない・実験的な理由で、などです。ほとんどの場合、新しいバージョンのリリースを待つより前のバージョンに戻したほうが問題が少ないと判断されます。

あるパッケージのダウングレードをすると、他のパッケージのダウングレードの必要が生じることもあります。実験的なパッケージを大量にインストールしたり、設定をいじくりまわした人にとっては、ダウングレードを試みるよりもシステムの再インストールをしたほうが好ましいかもしれません。

詳細

しかし、ユーザーは次のことを心に留めるべきです:

  • プログラムの依存性を考えて下さい。必要なライブラリのバージョンが変わるのがしょっちゅうで、挙動が以前と全く異なるようなとき、解決法は旧バージョンに変えることでしょう。
  • ファイルが削除された後ファイルが他のソースから入手できるかどうか考えて下さい。Arch Linux はローリングリリースであり、レポジトリは自動的にアップデートされ古いバージョンは保存されません。この問題については後に詳しく書きます。
  • 設定ファイルやスクリプトの変更に気をつけて下さい。今現在、pacman にはセーフガードがあり、それをバイパスしない限り、pacman がそれらを管理しています。

Arch Rollback Machine のコンセプトが完成して pacman に寄与されることが待たれています。そうすれば、ダウングレードは自動化されるでしょう。

パッケージをダウングレードする方法

  • Q: pacman -Syu をしたら XYZ パッケージがバージョンMからバージョンNにアップグレードされました。私の環境ではこのパッケージは問題があります、どうやったらバージョン N からバージョン M へダウングレードできますか?
  • A: /var/cache/pacman/pkg ディレクトリの中にもし古いバージョンのパッケージが保存されていた場合、簡単にダウングレードすることができます。(つい最近に pacman -Scc をしたりしていない限り存在しているはずです)。pacman -U /var/cache/pacman/pkg/pkgname-olderpkgver.pkg.tar.gz でその指定したバージョンのパッケージをインストールできます。

この方法では現在のパッケージを削除するので、慎重に依存性の変更を計算してください。そして依存性を破壊しないように古いバージョンをインストールします。

Note: OS の基幹的な部分を変えるのなら、文字通り数ダースものパッケージを古いバージョンに取り替える必要があるかもしれません。 Or they may just be gone and you will have to put them back in a manual, piece-meal fashion, while being careful that a particular upgrade does not want to re-install the undesirable package version you did not want in the first place.

また AURdowngrade というパッケージもあります。シンプルな Bash スクリプトで、キャッシュから古いバージョンのパッケージを探してくれます。キャッシュにないときは A.R.M. の検索も行います。あなたはインストールするパッケージを選ぶことができます。簡単に言えば、この記事に書かれていることを自動化してくれます。使用方法は downgrade --help をチェックして下さい。

より強力なツールに downgrader があります。これは pacman のログとして働くだけでなく、ARM やローカルキャッシュからパッケージをダウングレードしたり、パッケージのリストを回覧するのに使えます。(パッケージのアップグレードのあと、パッケージの名前がわからないとき便利です)。

カーネルのダウングレード

カーネルアップデートの後に起動できなくなった場合、livecd を使ってカーネルをダウングレードできます。なるべく最新の Arch Linux のインストールメディアを使って下さい。ブートしたら、システムのパーティションをマウント(たとえば /mnt に)し、もしパーティションが分割されていて /boot や /var があるならそれらもマウントしてください (mount /dev/sdc3 /mnt/boot)。そして proc などをマウントします。

mount -t proc proc /mnt/proc
mount -t sysfs sys /mnt/sys
mount -o bind /dev /mnt/dev

次に chroot を使います。chroot /mnt /bin/bash。それから /var/cache/pacman/pkg まで行き、パッケージをダウングレードします。少なくとも linuxlinux-headers そしてカーネルモジュールをダウングレードしてください。 例えば、

pacman -U linux-3.5.6-1-x86_64.pkg.tar.xz linux-headers-3.5.6-1-x86_64.pkg.tar.xz virtualbox-host-modules-4.2.0-5-x86_64.pkg.tar.xz

chroot を終了し、再起動すれば完了です。

もし特殊なセットアップ (lvm, encryption, ...) をしていたのなら、次の記事を参照してください: http://sch1zo.github.com/blog/2012/05/08/downgrading-a-bad-kernel-on-arch-with-luks-and-lvm/

古いバージョンのパッケージを見つける

3つの方法があります。

未同期のミラーサーバ

パソコンの中に古いバージョンが見つからなかった場合、未同期のサーバーで見つけられるかもしれません。こちらでミラーの状態を見ることができます。

Arch Rollback Machine

Note: オリジナルの Arch Rollback Machine は 2013-08-18 に終了しました [1]

Arch Rollback Machine は公式 Archlinux ミラーの毎日のスナップショットです。

ARM を参照してください。

パッケージのリコンパイル

最悪の場合、つまりパッケージがどこにも見つからない場合、古いバージョンを自分でコンパイルする必要があるかもしれません。これには PKGBUILD ファイルが必要です。ABS の PKGBUILD を古いリソースを使うように編集する、もしくは https://www.archlinux.org/packages/ にアクセスしてダウングレードしたいパッケージをさがしてください。見つけたら、"View Changes" をクリックして "log" を選択します。クリックして必要なバージョンの場所をつきとめて、ディレクトリにあるファイルをダウンロードして makepkg でビルドしてください。

AUR のパッケージでは、http://pkgbuild.com/git/aur-mirror.git/ にある古い PKGBUILD を使うか、Unofficial User Repositories でコンパイル済みのバイナリ(ときどき古いものが残っています)を探すのが唯一の方法です。

レポジトリの変更

ARM にレポジトリを変更したいときは、古い行をコメントアウトして適切なディレクトリの場所を /etc/pacman.conf に追加してください:

[core]
#Include = /etc/pacman.d/mirrorlist
Server=http://seblu.net/a/arm/2013/09/11/$repo/os/$arch

この例では、2013年9月11日時点で存在していた全てのパッケージが利用できます。

全てのリポジトリを ARM に変更するには、/etc/pacman.d/mirrorlist 内のミラーを更新して、ARM のミラーを一番上に置いて下さい。

##                                                                              
## Arch Linux repository mirrorlist                                             
## Generated on 2042-01-01                                                      
##
Server=http://seblu.net/a/arm/2013/09/11/$repo/os/$arch  

これで以下のコマンドを使ってパッケージを更新することができます:

pacman -Syy  # 同期データベースの更新
pacman -Suu  # リポジトリ内の低いバージョンに全てのパッケージをダウングレードする

詳しい情報は pacman (日本語) を見て下さい。

FAQ

Q: 依存性のせいでパッケージをダウングレードできません。

A: アップグレードや削除のとき 'd' を使って依存性を無視できます。例: pacman -Ud pkgpkgname-olderpkgver.pkg.tar.gz。システムを破壊する可能性もあるので気をつけて下さい。

Q: ダウングレードしたパッケージを pacman がアップデートしないようにするのにはどうしたらいいですか?

A: pacman.confIgnorePkg = package1 package2 と書けば --sysupgrade した時も Pacman は指定されたパッケージのアップグレードを無視します。

Q: システムを昨日の状態に戻したいのですが。

A: LVM を使って定期的にスナップショットを作れば簡単です。