ホームページ  >  記事  >  データベース  >  Docker コンテナからローカルでホストされている MySQL データベースに接続するにはどうすればよいですか?

Docker コンテナからローカルでホストされている MySQL データベースに接続するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-10-26 18:42:30195ブラウズ

How to Connect to a Locally Hosted MySQL Database from a Docker Container?

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 サイトの他の関連記事を参照してください。

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