summaryrefslogtreecommitdiff
path: root/clusters/example-distbuild-cluster.morph
blob: 5208a5ca16cb293e657a675a2e22b608b1b032eb (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
name: example-distbuild-cluster
kind: cluster
description: |
  This is an example cluster morph that can be adapted to set up a
  Baserock distributed build network.

  You will need to deploy a Trove for the distributed build network
  to use before deploying this cluster. The worker SSH key file should
  be generated as part of the Trove deployment. It is the key used by
  workers to authenticate with the Trove to give them read access to
  all source repositories.
systems:
- morph: systems/build-system-x86_64.morph
  deploy-defaults:
    CONTROLLERHOST: build-controller
    DISTBUILD_CONTROLLER: false
    DISTBUILD_WORKER: true
    FSTAB_SRC: LABEL=src /srv/distbuild auto defaults,rw,noatime 0 2
    INSTALL_FILES: install-files/distbuild/manifest
    NFSBOOT_CONFIGURE: true
    TROVE_ID: $MY_TROVE
    WORKER_SSH_KEY: ssh-keys/worker.key
  deploy:
    build-controller:
      type: extensions/nfsboot
      location: $MY_TROVE
      DISTBUILD_CONTROLLER: true
      HOSTNAME: build-controller
      WORKERS: build-node-1, build-node-2
    build-node-1:
      type: extensions/nfsboot
      location: $MY_TROVE
      HOSTNAME: build-node-1
    build-node-2:
      type: extensions/nfsboot
      location: $MY_TROVE
      HOSTNAME: build-node-2