4
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Dockerコンテナ間のAPI通信でハマった話 - host.docker.internalの存在

Last updated at Posted at 2024-03-22

追記(2024/07/16)

本記事はフロントエンドのNext.jsをSSRで使用する場合に該当します。CSRの場合は問題がありませんでした。

前提知識

  • Dockerを使って、フロントエンドとバックエンドを別々のコンテナで開発していた
  • フロントエンドにはNext.js14(AppRouter)、バックエンドにはRails7を使用

問題

フロントエンドからバックエンドへのAPI呼び出しを行おうとしたが、うまく通信ができなかった。
フロントエンドのコードでは、バックエンドのAPIエンドポイントをhttp://localhost:3000/api/...のように指定していた。

原因

Dockerコンテナ内ではlocalhostが指すのはコンテナ自身であり、別のコンテナを指すことができない。そのため、フロントエンドのコンテナからlocalhostを使ってバックエンドのコンテナにアクセスしようとしても、正しく通信ができなかった。

解決方法

Next.jsコンテナの設定

Dockerコンテナ間で通信を行う際には、host.docker.internalを使用する。host.docker.internalは、Dockerコンテナから見たホストマシンのIPアドレスを表す特殊なDNS名である。

フロントエンドのコードを以下のように修正する。

// 修正前
const apiEndpoint = 'http://localhost:3000/api/...';

// 修正後
const apiEndpoint = 'http://host.docker.internal:3000/api/...';

Railsコンテナの設定

Railsコンテナ側では、config/environments/development.rbファイルに以下の設定を追加する。

config.hosts << "host.docker.internal"

この設定により、RailsがDocker外部からのリクエストを受け付けるようになる。

これらの修正によって、Next.jsのコンテナからRailsのコンテナへの通信が正常に行えるようになる。

まとめ

  • Dockerコンテナ間でAPI通信を行う際は、localhostではなくhost.docker.internalを使用する必要がある
  • host.docker.internalは、Dockerコンテナから見たホストマシンのIPアドレスを表す特殊なDNS名
  • Next.jsコンテナではAPIエンドポイントの指定をhost.docker.internalに変更し、Railsコンテナではconfig.hostshost.docker.internalを追加する
  • Dockerを使った開発では、コンテナ間の通信方法を正しく理解しておくことが重要
4
5
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?