1つのDockerコンテナではなく、n個のdockerコンテナにあります。
理論的には、開発環境全体を1つのコンテナー内にアセンブルできますが、dockerはこれを行うことを意図していませんでした。
代わりに、docker composeを使用して各サービスを個別のコンテナーにデプロイし、インフラストラクチャ全体を単一のファイルで管理します。各サービスには、独自のログファイル、ユーザースペース、ネットワークなどがあります。
例を挙げましょう、これは私のドラフトです docker-compose.yml
version: '2'
services:
myproxy:
build: myproxy
container_name: ppproxy
ports:
- "80:80"
- "443:443"
volumes:
- /var/run/docker.sock:/tmp/docker.sock:ro
networks:
default:
aliases:
- www.domain1.it
- www.domain2.it
- www.domain4.it
mydb1:
build: mydb
environment:
DB_USER: sdffdssdf
DB_PASSWORD: fdsfsdsdf
DB_NAME: dbanme1
DB_ENCODING: UTF-8
VIRTUAL_HOST: myhost1.net.lan
VIRTUAL_PORT: 5432
mydb2:
build: mydb
environment:
DB_USER: ssdfsdfs
DB_PASSWORD: sffdssd
DB_NAME: dbanme2
DB_ENCODING: UTF-8
VIRTUAL_HOST: myhost2.net.lan
VIRTUAL_PORT: 5432
www:
image: myimages/oldservice:v1.1
container_name: www
command: /bin/bash /root/launch
environment:
VIRTUAL_HOST: www.domain1.it
VIRTUAL_PORT: 80
ports:
- 80
depends_on:
- mydb1
- mydb1
- myws
myws:
build: myjettycontainer
environment:
HTTPS_METHOD: noredirect
VIRTUAL_HOST: www.domain2.it
VIRTUAL_PORT: 8080
ports:
- 8080
depends_on:
- mydb1
- mydb2
- myproxy
- mypostfix
mypostfix:
image: catatnight/postfix
container_name: mailer
environment:
maildomain: domain1.it
smtp_user: mymail:sfsfdfds
ports:
- 25
nginxプロキシ(myproxy)、2つの同様のpostgresデータベース(mydb1および2)、古いjava webアプリケーションサーバー(www)、残りのwebサービスを提供するjava jettyコンテナー、最後に非常に単純なSMTP postfixコンテナーがあります。
すべてが起動します-通常:)-でdocker-compose up
、私の開発マシン上または本番環境で; ログファイルは読みやすい1つのファイルに集約され、ラップトップで動作する場合に動作することを保証して、ほぼすべての機能をローカルに複製することができます。