開発環境
Windows10
C#
.NET 5
ASP.NET Core MVC
PostgreSQL
開発は、ローカルIISとDocker上のPostgreSQLで行っています。
作成したWebアプリケーションをDocker上で運用しようと考えています。
WebAppは動いたのですが、DBとの接続ができず困っています。
WebAppとDBのコンテナ間通信をするには、どうしたらいいかご教授いただければと思います。
Dockerfile
CLI
1FROM mcr.microsoft.com/dotnet/aspnet:5.0 2COPY xxx/yyy App/ 3WORKDIR /App 4ENTRYPOINT ["dotnet", "appname.dll"]
下記でイメージ化&tarファイルにまとめる。
CLI
1docker build -t appname -f Dockerfile . 2docker save appname -o appname.tar
下記でtarファイルを展開、コンテナ作成&起動
CLI
1docker load -i appname.tar 2docker run -d -p 8080:80 --name appname appname
ConnectionStringは、appsettings.jsonに記載しています。
JSON
1"ConnectionString": {"XxxContext": "Host=127.0.0.1; Port=5433; Username=xxx; Password=yyy; Database=zzz;"}
PostgreSQLは、こんな感じです。
YAML
1version: '3' 2services: 3 db: 4 image: postgres:13-alpine 5 build: . 6 container_name: mypostgres 7 ports: 8 - "5433:5432" 9 environment: 10 TZ: Asia/Tokyo 11 POSTGRES_DB: test 12 POSTGRES_USER: admin 13 POSTGRES_PASSWORD: admin 14 POSTGRES_INITDB_ARGS: "--encoding=UTF-8" 15 volumes: 16 - ./docker/postgres/init.d:/docker-entrypoint-initdb.d 17 - ./docker/postgres/pgdata:/var/lib/postgresql/data 18 restart: always 19 hostname: mypostgres 20 pgadmin4: 21 image: dpage/pgadmin4 22 container_name: mypgadmin4 23 ports: 24 - "8000:80" 25 volumes: 26 - ./docker/pgadmin4:/var/lib/pgadmin 27 environment: 28 PGADMIN_DEFAULT_EMAIL: pgadmin4@pgadmin.org 29 PGADMIN_DEFAULT_PASSWORD: admin 30 hostname: mypgadmin4 31 depends_on: 32 - db 33 restart: always
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。