yum updateでsatyr.x86_64の更新に失敗する

yum updateを実行すると以下のメッセージが表示される。

# yum update
読み込んだプラグイン:fastestmirror, refresh-packagekit
Loading mirror speeds from cached hostfile
* base: ftp.nara.wide.ad.jp
* epel: ftp.kddilabs.jp
* extras: ftp.nara.wide.ad.jp
* updates: ftp.nara.wide.ad.jp
依存性の解決をしています
--> トランザクションの確認を実行しています。
---> パッケージ satyr.x86_64 0:0.13-4.el7 を 更新
---> パッケージ satyr.x86_64 0:0.14-2.el6 を アップデート
--> 依存性の処理をしています: librpm.so.1()(64bit) のパッケージ: satyr-0.14-2.el6.x86_64
--> 依存性解決を終了しました。
エラー: パッケージ: satyr-0.14-2.el6.x86_64 (epel)
             要求: librpm.so.1()(64bit)
問題を回避するために --skip-broken を用いることができます。

以下のyum list satyr.x86_64の実行結果を見て欲しい。

# yum list satyr.x86_64
読み込んだプラグイン:fastestmirror, refresh-packagekit
Loading mirror speeds from cached hostfile
* base: ftp.nara.wide.ad.jp
* epel: ftp.kddilabs.jp
* extras: ftp.nara.wide.ad.jp
* updates: ftp.nara.wide.ad.jp
インストール済みパッケージ
satyr.x86_64                                        0.13-4.el7                                         installed
利用可能なパッケージ
satyr.x86_64                                        0.14-2.el6                                         epel

この問題はEPEL( エンタープライズ Linux 用の拡張パッケージ)リポジトリに登録されているsatyr.x86_64のバージョンと、CentOS7のBASICリポジトリに登録されているsatyr.x86_64のバージョンが異なるために発生している。yumコマンドはEPELに登録されているバージョンの新しいsatyrに更新しようとするが、CentOSのBASICリポジトリに登録されている依存パッケージのバージョンが低いため更新に失敗する。
基本的に–skip-brokenオプションを指定して、無視してしまって問題ない。
もしどうしてもエラーが表示されるのが気持ちが悪いなら「EPELリポジトリを使うのを止めろ」という話になる。

CentOS 6.5 -> CentOS 7.0へのアップグレード

PHP5.3のサポートが2014年8月14日で終了するとアナウンスされていたので、いい加減にCentOS6.5からCentOS7.0へのアップグレードを行った。CentOS6.5に付随するPHPは5.3系、もちろんPHPだけ手作業で更新することもできるのだけど、CentOSのFull Updatesのサポート期限まで後1年もないし、良い機会なのでOS丸ごとアップデートすることにする。

実は今までLinuxをインストールするところまでで、まともに使ったことがないので、アップグレード作業は初めての経験。

CentOS6.5->7.0へのUpgrade

1.yum updateを実行して既存のアップデートを全て適用する。

2.preupgrade用のツールをインストールする。

必要なモジュールはhttp://dev.centos.org/centos/6/upg/x86_64/Packages/におかれているので、こちらよりダウンロードしてインストールする。以下のコマンドを実行。

yum -y install openscap pcre-devel libxml2-devel libxslt-devel m2crypto python-simplejson mod_wsgi
rpm -ihv http://dev.centos.org/centos/6/upg/x86_64/Packages/preupgrade-assistant-1.0.2-33.el6.x86_64.rpm
rpm -ihv http://dev.centos.org/centos/6/upg/x86_64/Packages/preupgrade-assistant-contents-0.5.13-1.el6.noarch.rpm
rpm -ihv http://dev.centos.org/centos/6/upg/x86_64/Packages/preupgrade-assistant-ui-1.0.2-33.el6.x86_64.rpm
rpm -ihv http://dev.centos.org/centos/6/upg/x86_64/Packages/python-rhsm-1.9.7-1.el6.x86_64.rpm
rpm -ihv http://dev.centos.org/centos/6/upg/x86_64/Packages/redhat-upgrade-tool-0.7.22-1.el6.noarch.rpm

2.preupgを実行してファイル更新の準備をする

次のコマンドを実行してファイルの更新を行う。

preupg

3.redhat-upgrade-toolを実行してファイルを更新する

次のコマンドを実行してファイルの更新を行う。かな~り時間がかかるので気長に待つ。

redhat-upgrade-tool --network 7.0  --instrepo http://ftp.iij.ad.jp/pub/linux/centos/7/os/x86_64/ --force

4.OSを再起動

5.再びyum updateを実行して既存のアップデートを全て適用する。

これで一応はCentOS7.0の環境に更新される。だがもともと動いていたWordpressは機能していない。CentOS6.5のインストール以後に変更した諸々の設定ファイルはCentOS6.5の時のままであったりするので、設定ファイルの見直しが必要になる。

WordPressの移行作業

1.mariadbのアンインストールとMySQLのインストール

CentOS 7.0ではMySQLの代わりにMariaDBがインストールされている。新規にインストールするならMariaDBに切り替えても良いのだけど、旧環境をできる限り生かしたいので、MariaDBをアンインストールして、新たにMySQLをインストールすることにする。

yum -y remove maria*
yum -y install http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
yum -y install mysql mysql-devel mysql-server mysql-utilities

2.Apatchの再設定

CentOS6.5の頃のApatchの設定ファイルがそのまま残っているが、Apatchのバージョンが上がっているため、その設定ファイルのままでは動作しない。httpd.conf.originalを元に改めて設定をやりなおす。この時modrewriteが無効になっているので、<Directory “/var/www/html”>のAllowOverride NoneをAllowOverride Allに変更する。

3.MySQLとApatchを起動する

デーモンを起動するコマンドがCentOS6.5とCentOS7.0では異なる。CentOS6.5ではserviceを使っていたが、CentOS7.0ではsystemctlコマンドを使用する。次のコマンドを実行してMySQLとApatchの自動起動する。

systemctl enable mysql
systemctl enable httpd

以上で、CentOS6.5 + WordPressの環境をCentOS7.0 + WordPressの環境に移行できる。初めてLinux系のOSでアップグレードしてみた訳だが・・・サーバーを2台以上用意できるなら新規にインストールしたほうが情報も多いし、トラブルも少なく、手っ取り早い気がorz

yum update実行時にAttributeError: ‘YumBaseCli’ object has no attribute ‘_not_found_i’が発生

2015-01-17 06:06:48

CentOS 6.5にてyum updateを行なったところ、以下のエラーが発生した。実のところ、Pythonのモジュールを色々入れてから、調子が悪い。

Traceback (most recent call last):
File "/usr/bin/yum", line 29, in
yummain.user_main(sys.argv[1:], exit_code=True)
File "/usr/share/yum-cli/yummain.py", line 288, in user_main
errcode = main(args)
File "/usr/share/yum-cli/yummain.py", line 223, in main
return_code = base.doTransaction()
File "/usr/share/yum-cli/cli.py", line 453, in doTransaction
lsts = self.listTransaction()
File "/usr/share/yum-cli/output.py", line 1055, in listTransaction
(_('Not installed'), self._not_found_i.values()),
AttributeError: 'YumBaseCli' object has no attribute '_not_found_i'

CentOSのページからyumのrpmファイルをダウンロードして、以下のコマンドを実行してyumの再インストールを行なったところ正常に動作するようになった。

rpm -ivh --replacepkgs yum-3.2.29-43.el6.centos.noarch.rpm

yumコマンドを実行するとpycurlでエラーになる

CentOS 6.5にてyumコマンドを実行すると以下のエラーが発生し、yumコマンドが動作しない。

# yum
There was a problem importing one of the Python modules
required to run yum. The error leading to this problem was:

pycurl: libcurl link-time ssl backend (nss) is different from compile-time ssl backend (none/other)

yumはPythonで作られている。そのためPython実行環境のライブラリバージョンと、yumコマンドが使用しているライブラリバージョンの整合性がとれなくなると動作しなくなる。

下記のコマンドを実行してpycurlを一度アンインストールした後、コンパイルオプションを指定して、再度pycurlをインストールする事で正常に動作した。

# pip uninstall pycurl
# export PYCURL_SSL_LIBRARY=nss
# pip install pycurl

参考URL