-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
69 lines (65 loc) · 1.72 KB
/
docker-compose.yml
File metadata and controls
69 lines (65 loc) · 1.72 KB
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
services:
db:
image: postgres:18.3
container_name: expense_splitter_database
environment:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: mysecretpassword
POSTGRES_DB: expense_splitter
ports:
- "5432:5432"
volumes:
- pgdata:/var/lib/postgresql
healthcheck:
test: ["CMD-SHELL", "pg_isready -U postgres -d expense_splitter"]
interval: 5s
timeout: 5s
retries: 20
db-init:
image: postgres:18.3
container_name: expense_splitter_db_init
depends_on:
db:
condition: service_healthy
working_dir: /workspace
volumes:
- ./:/workspace
environment:
PGPASSWORD: mysecretpassword
command: >
sh -c "
psql -h db -U postgres -d expense_splitter -f /workspace/db/schema.sql
"
builder:
image: maven:3.9.9-eclipse-temurin-21
container_name: expense_splitter_builder
working_dir: /workspace
depends_on:
db:
condition: service_healthy
volumes:
- ./:/workspace
- m2_cache:/root/.m2
command: >
sh -c "
mvn -f expense-splitter.standalone/pom.xml clean install &&
mvn -f expense-splitter/pom.xml clean package
"
app:
image: expense-splitter-image
container_name: expense_splitter_container
depends_on:
db:
condition: service_healthy
ports:
- "8080:8080"
environment:
SPRING_DATASOURCE_URL: jdbc:postgresql://db:5432/expense_splitter
SPRING_DATASOURCE_USERNAME: postgres
SPRING_DATASOURCE_PASSWORD: mysecretpassword
SPRING_JPA_HIBERNATE_DDL_AUTO: none
SPRING_JPA_PROPERTIES_HIBERNATE_DEFAULT_SCHEMA: expense_splitter
SPRING_JPA_OPEN_IN_VIEW: "false"
volumes:
pgdata:
m2_cache: