-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker-compose.yml
163 lines (152 loc) · 3.6 KB
/
docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
version: '3.3'
services:
# add nginx service
nginx:
image: nginx:alpine
container_name: nginx
depends_on:
- flask-template
ports:
- "80:80"
- "443:443"
networks:
- db
volumes:
- ./data/nginx:/etc/nginx/conf.d
- ./data/certbot/conf:/etc/letsencrypt
- ./data/certbot/www:/var/www/certbot
# Cerbot service to shh connection
certbot:
image: certbot/certbot
volumes:
- ./data/certbot/conf:/etc/letsencrypt
- ./data/certbot/www:/var/www/certbot
redis:
image: redis
container_name: redis
ports:
- 6379:6379
networks:
- celery
flask-template:
# this is used for development only, use the tagged registry image instead
image: imadmoussa1/flask-api-uwsgi
container_name: api
# ports:
# - 5000:5000
depends_on:
- postgres
- mongo
secrets:
- postgres_db_uri
- mongo_db_uri
environment:
# flush python stdout
- AUTHLIB_INSECURE_TRANSPORT=true
- PYTHONUNBUFFERED=1
env_file:
- ./configs/global.env
networks:
- db
volumes:
- ./blog_api:/var/app
mongo:
image: mongo
hostname: mongo
container_name: mongo
# ports:
# - 27017:27017
secrets:
- mongo_admin_username
- mongo_admin_password
environment:
MONGO_INITDB_ROOT_USERNAME_FILE: /run/secrets/mongo_admin_username
MONGO_INITDB_ROOT_PASSWORD_FILE: /run/secrets/mongo_admin_password
networks:
- db
volumes:
- mongo-volume:/data/db
postgres:
image: postgres
container_name: postgres
restart: always
# ports:
# - 5432:5432
secrets:
- postgres_admin_username
- postgres_admin_password
- postgres_db_name
environment:
POSTGRES_USER_FILE: /run/secrets/postgres_admin_username
POSTGRES_PASSWORD_FILE: /run/secrets/postgres_admin_password
POSTGRES_DB_FILE: /run/secrets/postgres_db_name
networks:
- db
volumes:
- postgres-volume:/var/lib/postgresql/data
pgadmin:
image: dpage/pgadmin4
container_name: pgadmin
restart: always
ports:
- "8082:80"
depends_on:
- postgres
environment:
PGADMIN_DEFAULT_EMAIL: [email protected]
PGADMIN_DEFAULT_PASSWORD: pgadminpassword
networks:
- db
volumes:
- pgadmin-volume:/var/lib/pgadmin
charts:
image: quay.io/mongodb/charts:19.09
hostname: charts
container_name: charts
depends_on:
- mongo
ports:
- 8083:80
volumes:
- keys:/mongodb-charts/volumes/keys
- logs:/mongodb-charts/volumes/logs
- db-certs:/mongodb-charts/volumes/db-certs
- web-certs:/mongodb-charts/volumes/web-certs
environment:
CHARTS_SUPPORT_WIDGET_AND_METRICS: "on"
networks:
- db
secrets:
- charts-mongodb-uri
networks:
db:
# this is used for development only
driver: bridge
celery:
# this is used for development only
driver: bridge
secrets:
mongo_admin_username:
file: ./secrets/mongo_admin_username.txt
mongo_admin_password:
file: ./secrets/mongo_admin_password.txt
mongo_db_uri:
file: ./secrets/mongo_db_uri.txt
postgres_admin_username:
file: ./secrets/postgres_admin_username.txt
postgres_admin_password:
file: ./secrets/postgres_admin_password.txt
postgres_db_name:
file: ./secrets/postgres_db_name.txt
postgres_db_uri:
file: ./secrets/postgres_db_uri.txt
charts-mongodb-uri:
file: ./secrets/charts_mongodb_uri.txt
volumes:
mongo-volume:
postgres-volume:
pgadmin-volume:
keys:
logs:
db-certs:
web-certs: