|
| 1 | +version: '3' |
| 2 | +services: |
| 3 | + minio: |
| 4 | + image: minio/minio |
| 5 | + ports: |
| 6 | + - "9000:9000" |
| 7 | + - "8090:8090" |
| 8 | + environment: |
| 9 | + - MINIO_ROOT_USER=minioadmin |
| 10 | + - MINIO_ROOT_PASSWORD=minioadmin |
| 11 | + volumes: |
| 12 | + - minio_data:/data |
| 13 | + command: server /data --console-address ":8090" |
| 14 | + healthcheck: |
| 15 | + test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"] |
| 16 | + interval: 5s |
| 17 | + timeout: 5s |
| 18 | + retries: 3 |
| 19 | + |
| 20 | + # a service simply to create the bucket |
| 21 | + minio-setup: |
| 22 | + image: minio/mc |
| 23 | + depends_on: |
| 24 | + minio: |
| 25 | + condition: service_healthy |
| 26 | + entrypoint: > |
| 27 | + /bin/sh -c " |
| 28 | + mc alias set myminio http://minio:9000 minioadmin minioadmin && |
| 29 | + mc mb --ignore-existing myminio/xtdb-bucket && |
| 30 | + echo 'MinIO bucket created successfully!'" |
| 31 | +
|
| 32 | + kafka: |
| 33 | + image: confluentinc/cp-kafka:7.7.1 |
| 34 | + expose: |
| 35 | + - 9092 |
| 36 | + - 9999 |
| 37 | + - 29092 |
| 38 | + - 29093 |
| 39 | + ports: |
| 40 | + - 29092:29092 |
| 41 | + - 29093:29093 |
| 42 | + environment: |
| 43 | + CLUSTER_ID: "1" |
| 44 | + KAFKA_PROCESS_ROLES: "broker,controller" |
| 45 | + KAFKA_NODE_ID: "1" |
| 46 | + KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: "CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT" |
| 47 | + KAFKA_ADVERTISED_LISTENERS: "PLAINTEXT://kafka:29092,PLAINTEXT_HOST://localhost:9092" |
| 48 | + KAFKA_CONTROLLER_QUORUM_VOTERS: "1@kafka:29093" |
| 49 | + KAFKA_LISTENERS: "PLAINTEXT://kafka:29092,CONTROLLER://kafka:29093,PLAINTEXT_HOST://0.0.0.0:9092" |
| 50 | + KAFKA_CONTROLLER_LISTENER_NAMES: "CONTROLLER" |
| 51 | + KAFKA_INTER_BROKER_LISTENER_NAME: "PLAINTEXT" |
| 52 | + KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: "1" |
| 53 | + |
| 54 | + # source postgres |
| 55 | + postgres: |
| 56 | + image: postgres:17-alpine |
| 57 | + ports: |
| 58 | + - "5434:5432" |
| 59 | + environment: |
| 60 | + POSTGRES_USER: postgres |
| 61 | + POSTGRES_PASSWORD: postgres |
| 62 | + POSTGRES_DB: sourcedb |
| 63 | + command: ["postgres", "-c", "wal_level=logical"] |
| 64 | + healthcheck: |
| 65 | + test: ["CMD-SHELL", "pg_isready -U postgres"] |
| 66 | + interval: 5s |
| 67 | + timeout: 5s |
| 68 | + retries: 5 |
| 69 | + |
| 70 | + # captures PG WAL → Kafka |
| 71 | + debezium-connect: |
| 72 | + image: quay.io/debezium/connect:3.0 |
| 73 | + depends_on: |
| 74 | + kafka: |
| 75 | + condition: service_started |
| 76 | + postgres: |
| 77 | + condition: service_healthy |
| 78 | + ports: |
| 79 | + - "8083:8083" |
| 80 | + environment: |
| 81 | + BOOTSTRAP_SERVERS: kafka:29092 |
| 82 | + GROUP_ID: "1" |
| 83 | + CONFIG_STORAGE_TOPIC: debezium_configs |
| 84 | + OFFSET_STORAGE_TOPIC: debezium_offsets |
| 85 | + STATUS_STORAGE_TOPIC: debezium_statuses |
| 86 | + |
| 87 | + debezium-init: |
| 88 | + image: curlimages/curl |
| 89 | + depends_on: |
| 90 | + - debezium-connect |
| 91 | + - postgres |
| 92 | + volumes: |
| 93 | + - ./register-connector.sh:/register-connector.sh:ro |
| 94 | + entrypoint: ["/bin/sh", "/register-connector.sh"] |
| 95 | + |
| 96 | + # main XTDB node (queryable via pgwire on :5433) |
| 97 | + xtdb: |
| 98 | + image: xtdb/xtdb-aws:latest |
| 99 | + depends_on: |
| 100 | + - kafka |
| 101 | + - minio-setup |
| 102 | + expose: |
| 103 | + - 8080 |
| 104 | + - 5432 |
| 105 | + - 9832 |
| 106 | + ports: |
| 107 | + - "8081:8080" |
| 108 | + - "5433:5432" |
| 109 | + - "9832:9832" |
| 110 | + environment: |
| 111 | + AWS_REGION: "aws-iso-global" |
| 112 | + AWS_S3_FORCE_PATH_STYLE: "true" |
| 113 | + AWS_S3_USE_VIRTUAL_HOSTING: "false" |
| 114 | + XTDB_NODE_ID: "xt-node-1" |
| 115 | + KAFKA_BOOTSTRAP_SERVERS: "kafka:29092" |
| 116 | + XTDB_LOG_TOPIC: "xt_log" |
| 117 | + XTDB_S3_BUCKET: "xtdb-bucket" |
| 118 | + XTDB_S3_ENDPOINT: "http://minio:9000" |
| 119 | + ACCESS_KEY: "minioadmin" |
| 120 | + SECRET_KEY: "minioadmin" |
| 121 | + command: ["-f", "/config/dc_config.yaml"] |
| 122 | + volumes: |
| 123 | + - ./dc_config.yaml:/config/dc_config.yaml |
| 124 | + |
| 125 | + # XTDB CDC node |
| 126 | + xtdb-cdc: |
| 127 | + image: xtdb/xtdb-aws:latest |
| 128 | + depends_on: |
| 129 | + - kafka |
| 130 | + - minio-setup |
| 131 | + - debezium-init |
| 132 | + environment: |
| 133 | + AWS_REGION: "aws-iso-global" |
| 134 | + AWS_S3_FORCE_PATH_STYLE: "true" |
| 135 | + AWS_S3_USE_VIRTUAL_HOSTING: "false" |
| 136 | + XTDB_NODE_ID: "xt-cdc-node" |
| 137 | + KAFKA_BOOTSTRAP_SERVERS: "kafka:29092" |
| 138 | + XTDB_LOG_TOPIC: "xt_log" |
| 139 | + XTDB_S3_BUCKET: "xtdb-bucket" |
| 140 | + XTDB_S3_ENDPOINT: "http://minio:9000" |
| 141 | + ACCESS_KEY: "minioadmin" |
| 142 | + SECRET_KEY: "minioadmin" |
| 143 | + command: ["debezium-cdc", "--kafka-cluster", "kafkaCluster", "-t", "sourcedb.public.cdc_demo", "-f", "/config/dc_config.yaml"] |
| 144 | + volumes: |
| 145 | + - ./dc_config.yaml:/config/dc_config.yaml |
| 146 | + |
| 147 | +volumes: |
| 148 | + minio_data: |
0 commit comments