docker-composeのコンテナへIPアドレスを設定して起動した際に発生するnetworks with user configured subnetsエラーの対応
docker-composeのコンテナへIPアドレスを設定して起動した際に発生するnetworks with user configured subnetsエラーの対応についてメモしました。
経緯
dockerでアプリを作成していてWebとDBのサーバーを切り離して利用できるようにしたかったため
docker-composeを分けて作成しました。
その際に別々のdocker-composeでもコンテナ同士の通信ができるように同一のnetworkに含めるようにしています。
ただ別々でコンテナを立ち上げると立ち上げた際にIPが自動的に割り振られることで再起動すると通信ができなくなってしまうことがあったため
IPを固定で起動できるように設定しました。
yaml// docker-compose.yaml
version: '3.5'
services:
db:
// 中略
networks:
sample_network:
ipv4_address: 172.18.0.10
networks:
sample_network:
sample_networkは下記コマンドで作成しました。
zsh$ docker network create -d bridge sample_network
環境
- Docker 20.10.2
- docker-compose 1.25.0
発生したエラー
docker-compose upコマンドで起動すると下記のエラーとなります。
zsh$ docker-compose up -d
Starting db ... error
ERROR: for db user specified IP address is supported only when connecting to networks with user configured subnets
IPを指定する場合はユーザーが構成したsubnetを持つ場合にのみサポートされますという内容です。
ネットワークを確認
ネットワークを確認するとsubnetは172.18.0.0/16へ割り当てられています。
コンテナへ指定した172.18.0.10もともとネットワークを作成した際に割り当てられた172.18.0.0/16の範囲で指定していたのですがなぜかエラーになってしまいます。
zsh$ docker network inspect sample_network
[
{
"Name": "sample_network",
"Id": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
"Created": "2021-06-21T22:40:08.169449156+09:00",
"Scope": "local",
"Driver": "bridge",
"EnableIPv6": false,
"IPAM": {
"Driver": "default",
"Options": {},
"Config": [
{
"Subnet": "172.18.0.0/16"
}
]
},
"Internal": false,
"Attachable": false,
"Ingress": false,
"ConfigFrom": {
"Network": ""
},
"ConfigOnly": false,
"Containers": {},
"Options": {},
"Labels": {}
}
]
subnetを指定してネットワークを作成し解決
subnetを指定して改めてネットワークを作成したら解決しました。
一度ネットワークを削除
docker network rmコマンドで削除します。
zsh$ docker network rm sample_network
subnetを指定してネットワークを再作成
subnetを指定してネットワークを再作成します。
zsh$ docker network create --subnet=172.18.0.0/16 sample_network
再度コンテナを起動
再度コンテナを起動したら無事起動しました。
zsh$ docker-compose up -d
Creating db ... done
dbコンテナへのアクセス
dbコンテナへのアクセスについても同一のsample_networkへ所属している別のコンテナから
172.18.0.10でアクセスすると無事アクセスすることができました。
yaml// docker-compose.yaml
version: '3.5'
services:
web:
// 中略
networks:
sample_network:
articleDocker イメージ署名と検証:cosign でサプライチェーンを防衛する運用手順
articleDocker で DNS 解決に失敗する時の原因と対処:overlay2・systemd-resolved・WSL2 対応
articleDocker を用いた統一ローカル環境:新人オンボーディングを 1 日 → 1 時間へ
articleDocker で Dev Container を構築:VS Code/Codespaces で即戦力環境を配布
articleDocker マルチステージビルド設計大全:テスト分離・依存最小化・キャッシュ戦略
articleDocker コマンド早見表:build/run/exec/logs/prune を 1 枚で網羅
articlePHP 基本文法を 90 分で速習:型宣言・null 合体・スプレッド構文の実践
articleHaystack チートシート:主要クラス・関数・CLI コマンド一枚まとめ
articleNotebookLM 活用事例:営業提案書の下書きと顧客要件の整理を自動化
articleGrok RAG 設計入門:社内ドキュメント検索を高精度にする構成パターン
articlegpt-oss 運用監視ダッシュボード設計:Prometheus/Grafana/OTel で可観測性強化
articleNode.js 標準テストランナー完全理解:`node:test` がもたらす新しい DX
blogiPhone 17シリーズの発表!全モデルiPhone 16から進化したポイントを見やすく整理
blogGoogleストアから訂正案内!Pixel 10ポイント有効期限「1年」表示は誤りだった
blog【2025年8月】Googleストア「ストアポイント」は1年表記はミス?2年ルールとの整合性を検証
blogGoogleストアの注文キャンセルはなぜ起きる?Pixel 10購入前に知るべき注意点
blogPixcel 10シリーズの発表!全モデル Pixcel 9 から進化したポイントを見やすく整理
blogフロントエンドエンジニアの成長戦略:コーチングで最速スキルアップする方法
review今の自分に満足していますか?『持たざる者の逆襲 まだ何者でもない君へ』溝口勇児
reviewついに語られた業界の裏側!『フジテレビの正体』堀江貴文が描くテレビ局の本当の姿
review愛する勇気を持てば人生が変わる!『幸せになる勇気』岸見一郎・古賀史健のアドラー実践編で真の幸福を手に入れる
review週末を変えれば年収も変わる!『世界の一流は「休日」に何をしているのか』越川慎司の一流週末メソッド
review新しい自分に会いに行こう!『自分の変え方』村岡大樹の認知科学コーチングで人生リセット
review科学革命から AI 時代へ!『サピエンス全史 下巻』ユヴァル・ノア・ハラリが予見する人類の未来