aboutsummaryrefslogtreecommitdiff
path: root/test/foundationdb/docker-compose.yml
blob: a1257d5c9b39eb04e2ed55bec54e1e07ca356333 (plain)
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
services:

  fdb1:
    image: ${FOUNDATIONDB_IMAGE:-foundationdb/foundationdb:7.1.61}
    environment:
      - FDB_CLUSTER_FILE_CONTENTS
      - FDB_NETWORKING_MODE=container
      - FDB_COORDINATOR_PORT=${FDB_PORT:-4500}
      - FDB_PORT=${FDB_PORT:-4500}
    networks:
      - fdb_network
    healthcheck:
      test: [ "CMD", "nc", "-z", "127.0.0.1", "4500" ]
      interval: 5s
      timeout: 5s
      retries: 60

  fdb2:
    image: ${FOUNDATIONDB_IMAGE:-foundationdb/foundationdb:7.1.61}
    environment:
      - FDB_CLUSTER_FILE_CONTENTS
      - FDB_NETWORKING_MODE=container
      - FDB_COORDINATOR_PORT=${FDB_PORT:-4500}
      - FDB_PORT=${FDB_PORT:-4500}
    networks:
      - fdb_network
    healthcheck:
      test: [ "CMD", "nc", "-z", "127.0.0.1", "4500" ]
      interval: 5s
      timeout: 5s
      retries: 60

  fdb3:
    image: ${FOUNDATIONDB_IMAGE:-foundationdb/foundationdb:7.1.61}
    environment:
      - FDB_CLUSTER_FILE_CONTENTS
      - FDB_NETWORKING_MODE=container
      - FDB_COORDINATOR_PORT=${FDB_PORT:-4500}
      - FDB_PORT=${FDB_PORT:-4500}
    networks:
      - fdb_network
    healthcheck:
      test: [ "CMD", "nc", "-z", "127.0.0.1", "4500" ]
      interval: 5s
      timeout: 5s
      retries: 60

  # Initialize and configure the database
  fdb-init:
    image: ${FOUNDATIONDB_IMAGE:-foundationdb/foundationdb:7.1.61}
    configs:
      - target: /var/fdb/config/fdb.cluster
        source: fdb.cluster
    environment:
      - FDB_CLUSTER_FILE=/var/fdb/config/fdb.cluster
    networks:
      - fdb_network
    depends_on:
      fdb1:
        condition: service_healthy
      fdb2:
        condition: service_healthy
      fdb3:
        condition: service_healthy
    entrypoint: |
      bash -c "
        set -o errexit
        # Wait for cluster to be ready
        sleep 10
        
        # Configure database
        echo 'Initializing FoundationDB database...'
        if ! fdbcli --exec 'configure new single ssd' >/tmp/fdbcli.out 2>&1; then
          if ! grep -qi 'ERROR: Database already exists!' /tmp/fdbcli.out >/dev/null 2>/dev/null; then
            echo 'ERROR: Database initialization failed!' >&2
            cat /tmp/fdbcli.out >&2
            exit 1
          fi
        fi
        
        # Wait for configuration to complete
        sleep 5
        
        # Verify cluster status
        fdbcli --exec 'status'
        
        echo 'FoundationDB cluster initialization complete!'
      "

  # SeaweedFS service with FoundationDB filer
  seaweedfs:
    image: ${SEAWEEDFS_IMAGE:-chrislusf/seaweedfs:latest}
    depends_on:
      fdb-init:
        condition: service_completed_successfully
    networks:
      - fdb_network
    ports:
      - "9333:9333"
      - "19333:19333"
      - "8888:8888"
      - "8333:8333"
      - "18888:18888"
    configs:
      - target: /var/fdb/config/fdb.cluster
        source: fdb.cluster
    volumes:
      - ./s3.json:/etc/seaweedfs/s3.json
      - ./filer.toml:/etc/seaweedfs/filer.toml
    environment:
      - WEED_LEVELDB2_ENABLED
      - WEED_FOUNDATIONDB_ENABLED
      - WEED_FOUNDATIONDB_CLUSTER_FILE
      - WEED_FOUNDATIONDB_API_VERSION
      - WEED_FOUNDATIONDB_TIMEOUT
      - WEED_FOUNDATIONDB_MAX_RETRY_DELAY
      - WEED_MASTER_VOLUME_GROWTH_COPY_1=1
      - WEED_MASTER_VOLUME_GROWTH_COPY_OTHER=1
    command: "weed server -ip=seaweedfs -filer -master.volumeSizeLimitMB=16 -volume.max=0 -volume -volume.preStopSeconds=1 -s3 -s3.config=/etc/seaweedfs/s3.json -s3.port=8333 -s3.allowEmptyFolder=false -s3.allowDeleteBucketNotEmpty=false"

configs:
  fdb.cluster:
    content: |
      ${FDB_CLUSTER_FILE_CONTENTS:-docker:docker@fdb1:4500,fdb2:4500,fdb3:4500}

networks:
  fdb_network:
    driver: bridge