-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yaml
107 lines (106 loc) · 4.3 KB
/
docker-compose.yaml
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
version: "3.6"
services:
postgres:
image: postgres:15
restart: always
volumes:
- db_data:/var/lib/postgresql/data
- ./hasura_discord_postgres/data:/docker-entrypoint-initdb.d
environment:
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
graphql-engine:
image: hasura/graphql-engine:v2.37.0.cli-migrations-v3
ports:
- "8080:8080"
restart: always
volumes:
- ./hasura_discord_postgres/postgres/metadata:/hasura-metadata
environment:
## postgres database to store Hasura metadata
HASURA_GRAPHQL_METADATA_DATABASE_URL: ${POSTGRES_URL}
## this env var can be used to add the above postgres database to Hasura as a data source. this can be removed/updated based on your needs
PG_DATABASE_URL: ${POSTGRES_URL}
HASURA_GRAPHQL_DATABASE_URL: ${POSTGRES_URL}
## enable the console served by server
HASURA_GRAPHQL_ENABLE_CONSOLE: "true" # set to "false" to disable console
## enable debugging mode. It is recommended to disable this in production
HASURA_GRAPHQL_DEV_MODE: "true"
HASURA_GRAPHQL_ENABLED_LOG_TYPES: startup, http-log, webhook-log, websocket-log, query-log
BACKEND_URL: ${BACKEND_URL}
BACKEND_SECRET: ${BACKEND_API_KEY}
## uncomment next line to run console offline (i.e load console assets from server instead of CDN)
# HASURA_GRAPHQL_CONSOLE_ASSETS_DIR: /srv/console-assets
## uncomment next line to set an admin secret
HASURA_GRAPHQL_ADMIN_SECRET: ${HASURA_GRAPHQL_ADMIN_SECRET}
HASURA_GRAPHQL_METADATA_DEFAULTS: '{"backend_configs":{"dataconnector":{"athena":{"uri":"http://data-connector-agent:8081/api/v1/athena"},"mariadb":{"uri":"http://data-connector-agent:8081/api/v1/mariadb"},"mysql8":{"uri":"http://data-connector-agent:8081/api/v1/mysql"},"oracle":{"uri":"http://data-connector-agent:8081/api/v1/oracle"},"snowflake":{"uri":"http://data-connector-agent:8081/api/v1/snowflake"}}}}'
depends_on:
data-connector-agent:
condition: service_healthy
data-connector-agent:
image: hasura/graphql-data-connector:v2.37.0
restart: always
ports:
- 8081:8081
environment:
QUARKUS_LOG_LEVEL: ERROR # FATAL, ERROR, WARN, INFO, DEBUG, TRACE
## https://quarkus.io/guides/opentelemetry#configuration-reference
QUARKUS_OPENTELEMETRY_ENABLED: "false"
## QUARKUS_OPENTELEMETRY_TRACER_EXPORTER_OTLP_ENDPOINT: http://jaeger:4317
healthcheck:
test: [ "CMD", "curl", "-f", "http://localhost:8081/api/v1/athena/health" ]
interval: 5s
timeout: 10s
retries: 5
start_period: 5s
qdrant:
image: qdrant/qdrant
ports:
- "6333:6333" # Change Qdrant to listen on a different port internally to avoid conflicts with Nginx
restart: always
volumes:
- qdrant_data:/var/lib/qdrant
- ./hasura_discord_qdrant/config.yaml:/qdrant/config/config.yaml
- ./hasura_discord_qdrant/snapshots:/snapshots # Mount the directory containing snapshots
command: >
/bin/sh -c "
./qdrant --snapshot /snapshots/v3.snapshot:v3 --force-snapshot
"
hasura_discord_bot:
build:
context: ./hasura_discord_bot
dockerfile: Dockerfile
environment:
CLIENT_SECRET: ${DISCORD_CLIENT_SECRET}
SEARCH_ENDPOINT_URL: ${SEARCH_ENDPOINT_URL}
SEARCH_ENDPOINT_API_KEY_HEADER: ${BACKEND_API_KEY_HEADER_NAME}
SEARCH_ENDPOINT_API_KEY: ${BACKEND_API_KEY}
GRAPHQL_URL: ${HASURA_GRAPHQL_URL}
GRAPHQL_ADMIN_SECRET: ${HASURA_GRAPHQL_ADMIN_SECRET}
GUILD_ID: ${GUILD_ID}
SYNC_ON_STARTUP: 1
depends_on:
graphql-engine:
condition: service_healthy
hasura_discord_backend:
build:
context: ./hasura_discord_backend
dockerfile: Dockerfile
ports:
- "8100:8100"
environment:
API_KEY_HEADER_NAME: ${BACKEND_API_KEY_HEADER_NAME}
API_KEY: ${BACKEND_API_KEY}
QDRANT_URL: ${QDRANT_URL}
QDRANT_API_KEY: ${QDRANT_API_KEY}
OPENAI_API_KEY: ${OPENAI_API_KEY}
OPENAI_ORGANIZATION: ${OPENAI_ORGANIZATION}
OPENAI_MODEL: ${OPENAI_MODEL}
OPENAI_EMBEDDING_MODEL: ${OPENAI_EMBEDDING_MODEL}
VECTOR_SIZE: ${VECTOR_SIZE}
GRAPHQL_URL: ${HASURA_GRAPHQL_URL}
GRAPHQL_ADMIN_SECRET: ${HASURA_GRAPHQL_ADMIN_SECRET}
OPENAI_CHAT_TEMPERATURE: 0.2
PORT: 8100
volumes:
db_data:
qdrant_data: