-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathdocker-compose.yml
142 lines (133 loc) · 4.87 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
version: "3.5"
name: lakefs-mount-demo
services:
jupyter-notebook:
build: ./jupyter
privileged: true
environment:
# log-level is set to WARN because of noisy stdout problem
# -> See https://github.com/jupyter-server/jupyter_server/issues/1279
- NOTEBOOK_ARGS=--log-level='WARN' --NotebookApp.token='' --NotebookApp.password='' --notebook-dir=/root --allow-root
- NB_USER=root
- NB_UID=0
- NB_GID=0
- CHOWN_HOME=yes
working_dir: /root
ports:
- 8892:8888 # Jupyter
volumes:
- $PWD:/root
- $PWD/../../data/alpaca_training_imgs:/root/alpaca_training_imgs
lakefs:
image: treeverse/lakefs:1
pull_policy: always
ports:
- "8084:8000"
depends_on:
postgres:
condition: service_healthy
minio-setup:
condition: service_completed_successfully
environment:
- LAKEFS_BLOCKSTORE_TYPE=s3
- LAKEFS_BLOCKSTORE_S3_FORCE_PATH_STYLE=true
- LAKEFS_BLOCKSTORE_S3_ENDPOINT=http://minio:9000
- LAKEFS_BLOCKSTORE_S3_CREDENTIALS_ACCESS_KEY_ID=minioadmin
- LAKEFS_BLOCKSTORE_S3_CREDENTIALS_SECRET_ACCESS_KEY=minioadmin
- LAKEFS_AUTH_ENCRYPT_SECRET_KEY=some random secret string
- LAKEFS_LOGGING_LEVEL=INFO
- LAKEFS_STATS_ENABLED=${LAKEFS_STATS_ENABLED:-1}
- LAKECTL_CREDENTIALS_ACCESS_KEY_ID=AKIAIOSFOLKFSSAMPLES
- LAKECTL_CREDENTIALS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
- LAKECTL_SERVER_ENDPOINT_URL=http://localhost:8000
- LAKEFS_DATABASE_TYPE=postgres
- LAKEFS_DATABASE_POSTGRES_CONNECTION_STRING=postgres://lakefs:lakefs@postgres/postgres?sslmode=disable
- LAKEFS_AUTH_API_ENDPOINT=http://fluffy:9006/api/v1
- LAKEFS_AUTH_UI_CONFIG_RBAC=internal
entrypoint: ["/bin/sh", "-c"]
command:
- |
lakefs setup --user-name everything-bagel --access-key-id "$$LAKECTL_CREDENTIALS_ACCESS_KEY_ID" --secret-access-key "$$LAKECTL_CREDENTIALS_SECRET_ACCESS_KEY" || true
lakefs run &
echo "---- Creating repository ----"
wait-for -t 60 lakefs:8000 -- lakectl repo create lakefs://quickstart s3://quickstart --sample-data || true
echo ""
wait-for -t 60 minio:9000 && echo '------------------------------------------------
MinIO admin: http://127.0.0.1:9005/
Username : minioadmin
Password : minioadmin
'
echo "------------------------------------------------"
wait-for -t 60 jupyter-notebook:8888 && echo '
Jupyter: http://127.0.0.1:8894/
'
echo "------------------------------------------------"
echo ""
echo "lakeFS Web UI: http://127.0.0.1:8084/ >(._.)<"
echo " ( )_ "
echo ""
echo " Access Key ID : $$LAKECTL_CREDENTIALS_ACCESS_KEY_ID"
echo " Secret Access Key: $$LAKECTL_CREDENTIALS_SECRET_ACCESS_KEY"
echo ""
echo "-------- Let's go and have axolotl fun! --------"
echo ""
wait
profiles:
- local-lakefs-enterprise
minio-setup:
image: minio/mc:RELEASE.2023-05-18T16-59-00Z
environment:
- MC_HOST_lakefs=http://minioadmin:minioadmin@minio:9000
depends_on:
- minio
volumes:
- ../../data:/data
entrypoint: ["/bin/sh", "-c"]
command:
- |
mc mb lakefs/quickstart lakefs/example lakefs/sample-data
mc cp --recursive /data/* lakefs/sample-data 1>/dev/null # don't be so noisy 🤫
profiles:
- local-lakefs-enterprise
minio:
image: minio/minio:RELEASE.2023-05-18T00-05-36Z
ports:
- "9004:9000"
- "9005:9001"
entrypoint: ["minio", "server", "/data", "--console-address", ":9001"]
profiles:
- local-lakefs-enterprise
postgres:
image: postgres:14
ports:
- "5433:5432"
environment:
POSTGRES_USER: lakefs
POSTGRES_PASSWORD: lakefs
healthcheck:
test: ["CMD", "pg_isready", "-U", "lakefs"]
interval: 10s
retries: 5
start_period: 5s
profiles:
- local-lakefs-enterprise
fluffy:
image: "${FLUFFY_REPO:-treeverse}/fluffy:${TAG:-latest}"
command: "${COMMAND:-run}"
ports:
- "8085:8000"
- "9006:9000"
depends_on:
- "postgres"
environment:
- FLUFFY_LOGGING_LEVEL=INFO
- FLUFFY_DATABASE_TYPE=postgres
- FLUFFY_DATABASE_POSTGRES_CONNECTION_STRING=postgres://lakefs:lakefs@postgres/postgres?sslmode=disable
- FLUFFY_AUTH_ENCRYPT_SECRET_KEY=some random secret string
- FLUFFY_AUTH_SERVE_LISTEN_ADDRESS=0.0.0.0:9006
entrypoint: [ "/app/wait-for", "postgres:5432", "--", "/app/fluffy" ]
profiles:
- local-lakefs-enterprise
networks:
default:
name: bagel