前回の記事にも書いたが、PHPを5.5にアップデートすると、
「php-mysql」が「php-mysqlnd」に置き換わるため、
以前のMySQLで作られていたユーザーのパスワードが古い形式のままの場合、
DBへ接続できない現象が発生する。
※yumによるアップデート
php-mysqlnd i686 5.5.0-0.28.beta4.el6.remi remi-test 248 k replacing php-mysql.i686 5.4.14-1.el6.remi
DB(mysql-userテーブル)を見てみると、
rootのパスワードは新形式の長いタイプのパスワードだが、
その他は短い古い形式のパスワードだった。
★ユーザーパスワードの確認 (DB:mysql / table:user)
よってパスワードを新形式へアップデートする事で解決できる!
※DB変更後は、必ずMySQLのサービスを再起動!
[sql]
SET PASSWORD FOR ‘対象のユーザー名’@’対象のホスト名’ = PASSWORD(‘対象となるユーザのパスワード’);
[/sql]
※上記SQLでOKだが直接updateしても変更できる、というか上の方がスマートだと知らなかった^^
[sql]
UPDATE
`mysql`.`user`
SET
`Password` = PASSWORD (‘対象となるユーザのパスワード’)
WHERE
`user`.`Host` = ‘対象のホスト名’ –(ユーザー名がユニークの場合は必要なし)
AND `user`.`User` = ‘対象のユーザー名’
;
[/sql]
スポンサードリンク
コメント