質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.40%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

1回答

677閲覧

LAMP環境でMySQL(127.0.0.1)へアクセスしようとするとエラーが発生する

erika.m

総合スコア46

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2024/06/19 11:53

編集2024/06/20 04:43

実現したいこと

同一サーバ上で動くPHPからMySQL(127.0.0.1)へとアクセスしたいです。

Apache:2.4.59
PHP:8.1.29(モジュール版)
MySQL:8.0.36

発生している問題・分からないこと

PHPからMySQLへアクセスしようとした際、ホスト名をlocalhostとした場合は問題なくアクセス可能ですが、127.0.0.1とするとエラーが発生します。

ただしサーバ上で直接MySQLクライアントから一度でもログイン(mysql -u ユーザ名 -p -h 127.0.0.1)すると、それ以降はPHPから127.0.0.1指定でもエラーが発生しなくなり、問題なくアクセス可能な状態になります。
なお上記で-hを指定しない場合や、mysql -u ユーザ名 -p -h localhost、とした場合はエラーは解消されず引き続きアクセスできないという状況です。

MySQLの設定では[mysqld]にskip-name-resolveを設定しています。
MySQLユーザがアクセス可能なhostは127.0.0.1、localhost共に許可しています。

エラーメッセージ

error

1Access denied for user 'ユーザ名'@'127.0.0.1' (using password: YES)

該当のソースコード

特になし

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

MySQLユーザのhostを%で全許可した場合も、同様にMySQL起動直後はPHPから127.0.0.1ではエラーになります。
ただし今度はサーバ上でのログイン時、ホストを指定しなくても(mysql -u ユーザ名 -p)一度ログインするだけで、上記同様にPHPからのMySQLアクセスも可能になります。

補足

以前、マイナーバージョンの違うMySQL:8.0.34で動かしていた時はこのような症状は出ていませんでした。
ただPHPやApacheのマイナーバージョンもその時より上がっているのでその辺りが影響している可能性も否定できません。

なお、コメントいただいたリンク先にあった下記を設定ファイルに追記してみても症状は変わらず、mysqldを再起動した直後はPHPからのアクセスはエラーが発生しました。

[mysqld] bind-address = 127.0.0.1

またfirewallについても正しく開放できている認識(firewall-cmdでmysqlサービス登録)でいますが、一度ログイン成功するとそれ以降はPHPからのアクセスでもエラーが発生しない症状から、firewallでブロックされている可能性も低いと思います。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yametai

2024/06/20 03:41

[mariadb - MySQL: ローカルホストには接続できるのに 127.0.0.1 には接続できない! ネットワーク設定やファイアウォールが原因? 解決方法を徹底解説!](https://sql-jp.dev/articles/264155577) 詳しくはないのですが、 上のリンク先の設定に関する情報も質問欄にご記載すると良いかもしれません。
erika.m

2024/06/20 04:45

コメントありがとうございます。補足追記しました。
sk_

2024/06/20 09:54

すみません、結論からいうとわかりませんでした。 ここまでに考えたことだけ書きます。 以降、カッコ内のように仮定した場合に理屈が通りそうな気がします。 1. PHPから127.0.0.1→失敗(MySQLが名前解決するときに::1からの接続だと判定) 2. mysqlから127.0.0.1→成功(127.0.0.1からの接続であり、名前解決の際に127.0.0.1=localhost(=::1?)であるとキャッシュされる) 3. その後、PHP127.0.0.1→成功(::1を逆引きしてlocalhost、localhostはキャッシュにあるので許可) MySQLユーザのhostを%で全許可した場合 1. PHPから127.0.0.1→失敗(???) 2. mysqlからh省略(=localhost)→成功(localhostからの接続であり、名前解決の際に127.0.0.1=localhostであるとキャッシュされる) 3. その後、PHP127.0.0.1→成功(::1を逆引きしてlocalhost、localhostはキャッシュにあるので許可) ぶっちゃけ、あんまりわかってないですが、 MySQLは次のような仕様であること、 * IPから逆引き→ドメインから正引き という手順を辿る(らしい) * 一度解決したホスト名は何らかの形でキャッシュされる(らしい) 加えて、PHPとしての接続元IPがv6として評価されているとしたら、という仮定で考えた結果が上記です。 それでもMySQLユーザのhostを%で全許可した場合に1の手順が弾かれるのに納得はいきません。 ただ、疑うようで申し訳ないですが、検証された手順の中で設定値を変更後、適用される前に操作されるなどして記載の状況が一部正確でないなら、上記のような仮定は当てはまるかもしれません。 MySQLの名前解決にはキャッシュがあるという前提で、もう一度検証すれば新たなヒントに巡り合うかもという気持ちもあります。。 その際には'ユーザ名'@'::1'も定義されて挙動を見るのが良いかと思います。 ※ご存知でしたらすみませんが、skip-name-resolveはlocalhostの名前解決には影響しません。(実際、書かれているようにlocalhostで接続できているかと思います) 支離滅裂ですみません。また何か思いついたら書きます。
erika.m

2024/06/20 13:00

ありがとうございます。 確かにキャッシュやIPv6は怪しい箇所ですが今のところ解消には至っておりません。
erika.m

2024/06/26 00:44

CentOS8を使っていて、IPv6関連の設定は停止させています。 一度ネットワーク周りの設定に注視しながら構築し直してみます。
guest

回答1

0

127.0.0.1のhostに対するユーザーを追加してください

SQL

1CREATE USER 'test'@'127.0.0.1' IDENTIFIED BY 'testpassword'; 2FLUSH PRIVILEGES;

作成後アクセス権は適当に付与してください

投稿2024/06/20 00:05

yambejp

総合スコア115870

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

erika.m

2024/06/20 00:32

本文中に記載していますがユーザは作成済みです。 分かり難くてすみません。 >MySQLユーザがアクセス可能なhostは127.0.0.1、localhost共に許可しています。
yambejp

2024/06/20 01:43

なんともいえませんが、 「ユーザー@%」の指定がされている場合はそちらの方の設定も必要なようです
erika.m

2024/06/20 01:52

%のユーザは作成していません。 「'ユーザ名'@'127.0.0.1'」と「'ユーザ名'@'localhost'」の2つのユーザを作成している時、質問内容に記載している症状が起こるという内容です。 その後試したこととして、hostを指定せず「'ユーザ名'@'%'」で作成し直してみると、少し症状は変化したがいずれにせよMySQL起動直後は127.0.0.1でアクセスできない、という質問内容を記載したつもりです。
yambejp

2024/06/20 02:06

127.0.0.1でログインしたときに select current_user(); するとホストは何になっていますか?
erika.m

2024/06/20 02:26

「$ mysql -u ユーザ名 -p -h 127.0.0.1」でログイン後、current_userを表示すると「ユーザ名@127.0.0.1」が表示されます。 「$ mysql -u ユーザ名 -p」とすると、current_userには「ユーザ名@localhost」が表示されます。 なおこちらも質問に記載していますが上記前者のログイン後であれば、PHPからもエラーが起こらずアクセス可能になる、という症状です。
gusachan

2024/06/25 12:22

/etc/hosts ファイルはどうなっていますか。以下追記してみては? 127.0.0.1 localhost
erika.m

2024/06/26 00:48

hostsにはデフォルトで登録されていて、IPv6のコメントアウトを試してみても変化がない状況です。 一応そのまま書き記しますが、内容は以下のとおりです。 127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4 #::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.40%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問