Docker コンテナからローカルでホストされている MySQL データベースに接続する
アプリケーションを運用環境に移行するときは、コンテナの使用を避けることが望ましいです。ホストされたデータベース。この記事では、Docker Compose を使用してローカルの MySQL データベースをコンテナ内で実行されているアプリケーションに接続する方法について説明します。
Docker Compose 構成
提供された Docker Compose 構成は、その使用方法を示しています。 MySQL データベース用の別の「app-db」サービスの。代わりにローカルの MySQL データベースに接続するには、次のように Compose ファイルを調整します。
<code class="yaml">version: '3' services: web-app: ... app-db: image: mysql:8 environment: - MYSQL_ROOT_PASSWORD=password - MYSQL_DATABASE=<database-name> ports: - 3306:3306</code>
ホスト名経由で接続
を参照する「localhost」を使用する代わりに、コンテナーの内部ホスト名には、「host.docker.internal」を使用します。これにより、Docker ホストの IP アドレスが解決され、ローカル データベースに接続できるようになります。
Linux 構成
Linux システムの場合、Docker の起動時に次のパラメータを追加します。コンテナ:
<code class="bash">--add-host host.docker.internal:host-gateway</code>
使用例
Web アプリケーションで、「localhost」の代わりに「host.docker.internal」を使用するようにデータベース接続情報を置き換えます。例:
db = mysql.connector.connect( host="host.docker.internal", ... )
これらの変更を実装すると、ローカルの MySQL データベースを Docker コンテナ内で実行されているアプリケーションに正常に接続できます。
以上がDocker コンテナからローカルでホストされている MySQL データベースに接続するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。