ホームページ 運用・保守 Docker docker が mysql に接続できない場合はどうすればよいですか?

docker が mysql に接続できない場合はどうすればよいですか?

Apr 18, 2023 am 09:48 AM

Docker を使用して MySQL データベースを構築すると、MySQL に接続できないという問題が発生することがあります。これは、ネットワークの問題、構成の問題、またはその他の問題が原因である可能性があります。この記事では、この問題を解決する方法について説明します。

1. ネットワーク接続を確認する

まず、Docker コンテナとローカル ホストの間のネットワーク接続が正常であることを確認する必要があります (ping コマンドで検出できます)。ローカル ホストでターミナルを開き、次のコマンドを実行します:

$ ping <docker容器IP>
ログイン後にコピー

このうち、 は、docker Inspection コマンドを使用して取得できます。

ping が正常に実行できる場合は、ネットワーク接続が正常であることを意味します。ping が正常に実行できない場合は、ネットワーク障害のトラブルシューティングを行う必要があります。

2. MySQL コンテナの設定を確認する

ネットワーク接続が正常であれば、MySQL コンテナの設定ファイルを確認する必要があります。以下のコマンドを実行します:

$ docker exec -it <container ID> /bin/bash
$ cd /etc/mysql
$ cat my.cnf
ログイン後にコピー

このうち、<コンテナID>はMySQLコンテナのIDです。

my.cnf ファイルの構成、特にネットワーク設定の構成が正しいかどうかを確認してください。

3. MySQL ユーザーを作成して認可する

MySQL コンテナの構成が正常な場合は、適切な MySQL ユーザーが作成され認可されているかどうかを確認する必要があります。

MySQL コンテナで、次のコマンドを実行します。

$ mysql -u root -p
ログイン後にコピー

root パスワードを入力して、MySQL コンソールに入ります。

次の SQL ステートメントを実行してユーザーを作成します。

CREATE USER 'username'@'%' IDENTIFIED BY 'password';
ログイン後にコピー

このうち、「ユーザー名」と「パスワード」は、それぞれ作成するユーザー名とパスワードです。

次に、ユーザーを承認します。

GRANT ALL ON *.* TO 'username'@'%';
ログイン後にコピー

ここで、「username」は、先ほど作成したユーザー名です。

最後に、次のコマンドを実行して変更を保存し、MySQL コンソールを終了します:

FLUSH PRIVILEGES;
EXIT;
ログイン後にコピー

4. ファイアウォール設定を確認します

それでも MySQL に接続できない場合は、ファイアウォールの設定に問題があることが原因である可能性があります。 MySQL 接続をブロックするファイアウォールがあるかどうかを確認する必要があります。

ローカルホストで次のコマンドを実行して、ポートがファイアウォールで占有されているかどうかを確認します:

$ sudo netstat -tunlp | grep <MySQL容器端口>
ログイン後にコピー

このうち、 は、MySQL サービスによって公開されるポート番号です。 。

ポートがすでに使用されている場合は、ポートを有効にする必要があります。 Ubuntu システムを例として、次のコマンドを実行してポートを開きます:

$ sudo ufw allow <MySQL容器端口>/tcp
ログイン後にコピー

このうち、 は、MySQL サービスによって公開されるポート番号です。

別のオペレーティング システムの場合は、対応するオペレーティング システムの設定に従ってポートを開く必要があります。

5. MySQL コンテナを再起動します

最後に、上記の 4 つの手順で問題が解決しない場合は、MySQL コンテナを再起動してみてください。

次のコマンドを使用して MySQL コンテナを再起動できます:

$ docker restart <container ID>
ログイン後にコピー

このうち、<コンテナ ID> は MySQL コンテナの ID です。

概要

Docker MySQL に接続できない問題はさまざまな理由で発生する可能性があるため、それらを 1 つずつ解決する必要があります。まずネットワーク接続が正常であるかどうかを確認し、次に MySQL コンテナの構成を確認し、MySQL ユーザーを作成して認可し、ファイアウォールの設定を確認して、最後に MySQL コンテナを再起動してみます。上記のどの手順でも問題が解決しない場合は、別の MySQL イメージに変更するか、他の解決策を探すことを検討してください。

以上がdocker が mysql に接続できない場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Dockerによってコンテナを出る方法 Dockerによってコンテナを出る方法 Apr 15, 2025 pm 12:15 PM

Dockerコンテナを終了する4つの方法:コンテナ端子でCtrl Dを使用するコンテナターミナルに出口コマンドを入力しますDocker stop&lt; container_name&gt;コマンドを使用するDocker Kill&lt; container_name&gt;ホストターミナルのコマンド(フォース出口)

Dockerインタビューの質問:DevOpsエンジニアリングインタビューをエース Dockerインタビューの質問:DevOpsエンジニアリングインタビューをエース Apr 06, 2025 am 12:01 AM

Dockerは、DevOpsエンジニアにとって必須のスキルです。 1.Dockerは、アプリケーションとその依存関係をコンテナにパッケージ化することにより、分離と移植性を実現するオープンソースのコンテナ化されたプラットフォームです。 2. Dockerは、名前空間、コントロールグループ、フェデレーションファイルシステムで動作します。 3。基本的な使用には、コンテナの作成、実行、管理が含まれます。 4.高度な使用法には、DockerComposeを使用してマルチコンテナーアプリケーションを管理することが含まれます。 5.一般的なエラーには、コンテナ障害、ポートマッピングの問題、データの持続性の問題が含まれます。デバッグスキルには、ログの表示、コンテナの入り、および詳細情報の表示が含まれます。 6.パフォーマンスの最適化とベストプラクティスには、画像の最適化、リソースの制約、ネットワーク最適化、DockerFileを使用するためのベストプラクティスが含まれます。

Dockerボリューム:コンテナ内の永続的なデータの管理 Dockerボリューム:コンテナ内の永続的なデータの管理 Apr 04, 2025 am 12:19 AM

Dockervolumeは、コンテナを再起動、削除、または移行すると、データが安全であることが保証されます。 1。ボリュームの作成:Dockervolumecreatemydata。 2。コンテナとマウントボリュームを実行します:Dockerrun-It-Vmydata:/app/dataubuntubash。 3.高度な使用には、データ共有とバックアップが含まれます。

Dockerのファイルを外部にコピーする方法 Dockerのファイルを外部にコピーする方法 Apr 15, 2025 pm 12:12 PM

Dockerの外部ホストにファイルをコピーする方法:Docker CPコマンドを使用:Docker CP [Options]&lt; Container Path&gt; &lt;ホストパス&gt;。データボリュームの使用:ホストにディレクトリを作成し、-vパラメーターを使用してコンテナを作成するときにディレクトリをコンテナにマウントして、双方向ファイルの同期を実現します。

Dockerの画像を更新する方法 Dockerの画像を更新する方法 Apr 15, 2025 pm 12:03 PM

Docker画像を更新する手順は次のとおりです。最新の画像タグ新しい画像をプルする新しい画像は、特定のタグのために古い画像を削除します(オプション)コンテナを再起動します(必要に応じて)

Dockerコンテナの名前を確認する方法 Dockerコンテナの名前を確認する方法 Apr 15, 2025 pm 12:21 PM

すべてのコンテナ(Docker PS)をリストする手順に従って、Dockerコンテナ名を照会できます。コンテナリストをフィルタリングします(GREPコマンドを使用)。コンテナ名(「名前」列にあります)を取得します。

Dockerを再起動する方法 Dockerを再起動する方法 Apr 15, 2025 pm 12:06 PM

Dockerコンテナを再起動する方法:コンテナID(Docker PS)を取得します。コンテナを停止します(docker stop&lt; container_id&gt;);コンテナを起動します(docker start&lt; container_id&gt;);再起動が成功していることを確認します(Docker PS)。その他の方法:Docker Compose(Docker-Compose Restart)またはDocker API(Dockerドキュメントを参照)。

Dockerプロセスを表示する方法 Dockerプロセスを表示する方法 Apr 15, 2025 am 11:48 AM

Dockerプロセス表示方法:1。DockerCLIコマンド:Docker PS; 2。SystemDCLIコマンド:SystemCTL Status Docker; 3。CLIコマンドを作成するDocker:Docker-Compose PS。 4。プロセスエクスプローラー(Windows); 5。 /procディレクトリ(Linux)。

See all articles