mirror of
https://github.com/PostHog/posthog.git
synced 2024-11-25 11:17:50 +01:00
299 lines
9.1 KiB
YAML
299 lines
9.1 KiB
YAML
#
|
|
# docker-compose base file used for local development, hobby deploys, and other compose use cases.
|
|
#
|
|
|
|
services:
|
|
proxy:
|
|
image: caddy
|
|
entrypoint: sh
|
|
restart: always
|
|
command: -c 'set -x && echo "$$CADDYFILE" > /etc/caddy/Caddyfile && exec caddy run -c /etc/caddy/Caddyfile'
|
|
volumes:
|
|
- /root/.caddy
|
|
environment:
|
|
CADDYFILE: |
|
|
http://localhost:8000 {
|
|
@replay-capture {
|
|
path /s
|
|
path /s/*
|
|
}
|
|
|
|
@capture {
|
|
path /e
|
|
path /e/*
|
|
path /i/v0/e
|
|
path /i/v0/e*
|
|
path /batch
|
|
path /batch*
|
|
path /capture
|
|
path /capture*
|
|
}
|
|
|
|
handle @capture {
|
|
reverse_proxy capture:3000
|
|
}
|
|
|
|
handle @replay-capture {
|
|
reverse_proxy replay-capture:3000
|
|
}
|
|
|
|
handle {
|
|
reverse_proxy web:8000
|
|
}
|
|
}
|
|
|
|
db:
|
|
image: postgres:12-alpine
|
|
restart: on-failure
|
|
environment:
|
|
POSTGRES_USER: posthog
|
|
POSTGRES_DB: posthog
|
|
POSTGRES_PASSWORD: posthog
|
|
healthcheck:
|
|
test: ['CMD-SHELL', 'pg_isready -U posthog']
|
|
interval: 5s
|
|
timeout: 5s
|
|
|
|
redis:
|
|
image: redis:6.2.7-alpine
|
|
restart: on-failure
|
|
command: redis-server --maxmemory-policy allkeys-lru --maxmemory 200mb
|
|
healthcheck:
|
|
test: ['CMD', 'redis-cli', 'ping']
|
|
interval: 3s
|
|
timeout: 10s
|
|
retries: 10
|
|
|
|
redis7:
|
|
image: redis:7.2-alpine
|
|
restart: on-failure
|
|
command: redis-server --maxmemory-policy allkeys-lru --maxmemory 200mb
|
|
healthcheck:
|
|
test: ['CMD', 'redis-cli', 'ping']
|
|
interval: 3s
|
|
timeout: 10s
|
|
retries: 10
|
|
|
|
clickhouse:
|
|
#
|
|
# Note: please keep the default version in sync across
|
|
# `posthog` and the `charts-clickhouse` repos
|
|
#
|
|
image: ${CLICKHOUSE_SERVER_IMAGE:-clickhouse/clickhouse-server:24.8.5.115}
|
|
restart: on-failure
|
|
|
|
zookeeper:
|
|
image: zookeeper:3.7.0
|
|
restart: on-failure
|
|
|
|
kafka:
|
|
image: ghcr.io/posthog/kafka-container:v2.8.2
|
|
restart: on-failure
|
|
environment:
|
|
KAFKA_BROKER_ID: 1001
|
|
KAFKA_CFG_RESERVED_BROKER_MAX_ID: 1001
|
|
KAFKA_CFG_LISTENERS: PLAINTEXT://:9092
|
|
KAFKA_CFG_ADVERTISED_LISTENERS: PLAINTEXT://kafka:9092
|
|
KAFKA_CFG_ZOOKEEPER_CONNECT: zookeeper:2181
|
|
ALLOW_PLAINTEXT_LISTENER: 'true'
|
|
healthcheck:
|
|
test: kafka-cluster.sh cluster-id --bootstrap-server localhost:9092 || exit 1
|
|
interval: 3s
|
|
timeout: 10s
|
|
retries: 10
|
|
|
|
kafka_ui:
|
|
image: provectuslabs/kafka-ui:latest
|
|
restart: on-failure
|
|
environment:
|
|
KAFKA_CLUSTERS_0_NAME: local
|
|
KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS: kafka:9092
|
|
DYNAMIC_CONFIG_ENABLED: 'true'
|
|
|
|
objectstorage:
|
|
image: minio/minio:RELEASE.2022-06-25T15-50-16Z
|
|
restart: on-failure
|
|
environment:
|
|
MINIO_ROOT_USER: object_storage_root_user
|
|
MINIO_ROOT_PASSWORD: object_storage_root_password
|
|
entrypoint: sh
|
|
command: -c 'mkdir -p /data/posthog && minio server --address ":19000" --console-address ":19001" /data' # create the 'posthog' bucket before starting the service
|
|
|
|
maildev:
|
|
image: maildev/maildev:2.0.5
|
|
restart: on-failure
|
|
|
|
flower:
|
|
image: mher/flower:2.0.0
|
|
restart: on-failure
|
|
environment:
|
|
FLOWER_PORT: 5555
|
|
CELERY_BROKER_URL: redis://redis:6379
|
|
|
|
worker: &worker
|
|
command: ./bin/docker-worker-celery --with-scheduler
|
|
restart: on-failure
|
|
environment: &worker_env
|
|
DISABLE_SECURE_SSL_REDIRECT: 'true'
|
|
IS_BEHIND_PROXY: 'true'
|
|
DATABASE_URL: 'postgres://posthog:posthog@db:5432/posthog'
|
|
CLICKHOUSE_HOST: 'clickhouse'
|
|
CLICKHOUSE_DATABASE: 'posthog'
|
|
CLICKHOUSE_SECURE: 'false'
|
|
CLICKHOUSE_VERIFY: 'false'
|
|
KAFKA_HOSTS: 'kafka'
|
|
REDIS_URL: 'redis://redis:6379/'
|
|
PGHOST: db
|
|
PGUSER: posthog
|
|
PGPASSWORD: posthog
|
|
DEPLOYMENT: hobby
|
|
|
|
web:
|
|
<<: *worker
|
|
command: ./bin/start-backend & ./bin/start-frontend
|
|
restart: on-failure
|
|
|
|
capture:
|
|
image: ghcr.io/posthog/posthog/capture:master
|
|
build:
|
|
context: rust/
|
|
args:
|
|
BIN: capture
|
|
restart: on-failure
|
|
environment:
|
|
ADDRESS: '0.0.0.0:3000'
|
|
KAFKA_TOPIC: 'events_plugin_ingestion'
|
|
KAFKA_HOSTS: 'kafka:9092'
|
|
REDIS_URL: 'redis://redis:6379/'
|
|
CAPTURE_MODE: events
|
|
|
|
replay-capture:
|
|
image: ghcr.io/posthog/posthog/capture:master
|
|
build:
|
|
context: rust/
|
|
args:
|
|
BIN: capture
|
|
restart: on-failure
|
|
environment:
|
|
ADDRESS: '0.0.0.0:3000'
|
|
KAFKA_TOPIC: 'session_recording_snapshot_item_events'
|
|
KAFKA_HOSTS: 'kafka:9092'
|
|
REDIS_URL: 'redis://redis:6379/'
|
|
CAPTURE_MODE: recordings
|
|
|
|
property-defs-rs:
|
|
image: ghcr.io/posthog/posthog/property-defs-rs:master
|
|
build:
|
|
context: rust/
|
|
args:
|
|
BIN: property-defs-rs
|
|
restart: on-failure
|
|
environment:
|
|
DATABASE_URL: 'postgres://posthog:posthog@db:5432/posthog'
|
|
KAFKA_HOSTS: 'kafka:9092'
|
|
SKIP_WRITES: 'false'
|
|
SKIP_READS: 'false'
|
|
FILTER_MODE: 'opt-out'
|
|
|
|
plugins:
|
|
command: ./bin/plugin-server --no-restart-loop
|
|
restart: on-failure
|
|
environment:
|
|
DATABASE_URL: 'postgres://posthog:posthog@db:5432/posthog'
|
|
KAFKA_HOSTS: 'kafka:9092'
|
|
REDIS_URL: 'redis://redis:6379/'
|
|
CLICKHOUSE_HOST: 'clickhouse'
|
|
CLICKHOUSE_DATABASE: 'posthog'
|
|
CLICKHOUSE_SECURE: 'false'
|
|
CLICKHOUSE_VERIFY: 'false'
|
|
|
|
livestream:
|
|
image: 'ghcr.io/posthog/livestream:main'
|
|
restart: on-failure
|
|
depends_on:
|
|
kafka:
|
|
condition: service_started
|
|
|
|
migrate:
|
|
<<: *worker
|
|
command: sh -c "
|
|
python manage.py migrate
|
|
&& python manage.py migrate_clickhouse
|
|
&& python manage.py run_async_migrations
|
|
"
|
|
restart: 'no'
|
|
deploy:
|
|
replicas: 0
|
|
|
|
asyncmigrationscheck:
|
|
<<: *worker
|
|
command: python manage.py run_async_migrations --check
|
|
restart: 'no'
|
|
deploy:
|
|
replicas: 0
|
|
environment:
|
|
<<: *worker_env
|
|
SKIP_ASYNC_MIGRATIONS_SETUP: 0
|
|
|
|
# Temporal containers
|
|
elasticsearch:
|
|
environment:
|
|
- cluster.routing.allocation.disk.threshold_enabled=true
|
|
- cluster.routing.allocation.disk.watermark.low=512mb
|
|
- cluster.routing.allocation.disk.watermark.high=256mb
|
|
- cluster.routing.allocation.disk.watermark.flood_stage=128mb
|
|
- discovery.type=single-node
|
|
- ES_JAVA_OPTS=-Xms256m -Xmx256m
|
|
- xpack.security.enabled=false
|
|
image: elasticsearch:7.16.2
|
|
expose:
|
|
- 9200
|
|
volumes:
|
|
- /var/lib/elasticsearch/data
|
|
temporal:
|
|
restart: on-failure
|
|
environment:
|
|
- DB=postgresql
|
|
- DB_PORT=5432
|
|
- POSTGRES_USER=posthog
|
|
- POSTGRES_PWD=posthog
|
|
- POSTGRES_SEEDS=db
|
|
- DYNAMIC_CONFIG_FILE_PATH=config/dynamicconfig/development-sql.yaml
|
|
- ENABLE_ES=true
|
|
- ES_SEEDS=elasticsearch
|
|
- ES_VERSION=v7
|
|
image: temporalio/auto-setup:1.20.0
|
|
ports:
|
|
- 7233:7233
|
|
labels:
|
|
kompose.volume.type: configMap
|
|
volumes:
|
|
- ./docker/temporal/dynamicconfig:/etc/temporal/config/dynamicconfig
|
|
depends_on:
|
|
db:
|
|
condition: service_healthy
|
|
elasticsearch:
|
|
condition: service_started
|
|
|
|
temporal-admin-tools:
|
|
environment:
|
|
- TEMPORAL_CLI_ADDRESS=temporal:7233
|
|
image: temporalio/admin-tools:1.20.0
|
|
stdin_open: true
|
|
tty: true
|
|
temporal-ui:
|
|
environment:
|
|
- TEMPORAL_ADDRESS=temporal:7233
|
|
- TEMPORAL_CORS_ORIGINS=http://localhost:3000
|
|
- TEMPORAL_CSRF_COOKIE_INSECURE=true
|
|
image: temporalio/ui:2.31.2
|
|
ports:
|
|
- 8081:8080
|
|
temporal-django-worker:
|
|
<<: *worker
|
|
command: ./bin/temporal-django-worker
|
|
restart: on-failure
|
|
environment:
|
|
<<: *worker_env
|
|
TEMPORAL_HOST: temporal
|