forked from cynkra/dm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker-compose.yml
119 lines (113 loc) · 3.22 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
# See .github/CONTRIBUTING.md for details.
# FIXME: Does docker-compose have an include directive so that the file can be split into multiple files?
version: '3'
volumes:
postgres-db:
driver: local
maria-db:
driver: local
mssql-db:
driver: local
networks:
postgres-network:
driver: bridge
mssql-network:
driver: bridge
services:
# https://www.beekeeperstudio.io/blog/how-to-use-mariadb-with-docker
mysql:
# FIXME: Still need to add Makefile rules to provision MySQL database
container_name: mysql
image: mysql
environment:
MYSQL_ROOT_PASSWORD: "YourStrong!Passw0rd"
MYSQL_DATABASE: test
MYSQL_USER: compose
MYSQL_PASSWORD: "YourStrong!Passw0rd"
ports:
- "3307:3306"
maria:
container_name: maria
image: mariadb
environment:
MARIADB_ROOT_PASSWORD: "YourStrong!Passw0rd"
MARIADB_DATABASE: test
MARIADB_USER: compose
MARIADB_PASSWORD: "YourStrong!Passw0rd"
volumes:
- maria-db:/var/lib/mysql
ports:
- "3306:3306"
# https://blog.logrocket.com/docker-sql-server/
mssql:
container_name: mssql
image: mcr.microsoft.com/mssql/server:2022-RTM-ubuntu-20.04
platform: linux/amd64
environment:
SA_PASSWORD: "YourStrong!Passw0rd"
ACCEPT_EULA: "Y"
healthcheck:
test: /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P "YourStrong!Passw0rd" -Q "SELECT 1" -b -o /dev/null
interval: 10s
timeout: 3s
retries: 10
start_period: 10s
volumes:
- mssql-db:/var/opt/mssql
ports:
- "1433:1433"
networks:
- mssql-network
init_mssql:
container_name: init_mssql
image: ghcr.io/cynkra/dm:main
platform: linux/amd64
environment:
# FIXME Kirill: Handle differently, perhaps using the default code path
DM_TEST_DOCKER_HOST: mssql
SA_PASSWORD: "YourStrong!Passw0rd"
ACCEPT_EULA: "Y"
depends_on:
mssql:
condition: service_healthy
networks:
- mssql-network
volumes:
- .:/root/workspace
- mssql-db:/var/opt/mssql
command: ["R", "-q", "-e", "suppressMessages(pkgload::load_all()); try(DBI::dbExecute(test_src_mssql(FALSE)[['con']], 'CREATE DATABASE test'))"]
# FIXME: Move code to standalone script
# FIXME: Wait until mssql is ready (healthcheck enough?=
# FIXME: Write a dummy file into the mssql-db value to ensure that the init_mssql container is run only once
# https://geshan.com.np/blog/2021/12/docker-postgres/
postgres:
container_name: postgres
# FIXME: brittle tests fail with latest PostgreSQL
image: postgres:14
environment:
POSTGRES_USER: compose
POSTGRES_PASSWORD: "YourStrong!Passw0rd"
volumes:
- postgres-db:/var/lib/postgresql/data
ports:
- "5432:5432"
networks:
- postgres-network
rdm_mssql:
container_name: rdm_mssql
image: ghcr.io/cynkra/dm:main
platform: linux/amd64
environment:
DM_TEST_DOCKER_HOST: mssql
SA_PASSWORD: "YourStrong!Passw0rd"
ACCEPT_EULA: "Y"
depends_on:
init_mssql:
condition: service_completed_successfully
networks:
- mssql-network
volumes:
- .:/root/workspace
tty: true
stdin_open: true
entrypoint: ["R"]