Alex Auvolat
c94406f428
- change the terminology: the network configuration becomes the role table, the configuration of a nodes becomes a node's role - the modification of the role table takes place in two steps: first, changes are staged in a CRDT data structure. Then, once the user is happy with the changes, they can commit them all at once (or revert them). - update documentation - fix tests - implement smarter partition assignation algorithm This patch breaks the format of the network configuration: when migrating, the cluster will be in a state where no roles are assigned. All roles must be re-assigned and commited at once. This migration should not pose an issue.
31 lines
756 B
Bash
Executable file
31 lines
756 B
Bash
Executable file
#!/bin/bash
|
|
|
|
set -ex
|
|
|
|
SCRIPT_FOLDER="`dirname \"$0\"`"
|
|
REPO_FOLDER="${SCRIPT_FOLDER}/../"
|
|
GARAGE_DEBUG="${REPO_FOLDER}/target/debug/"
|
|
GARAGE_RELEASE="${REPO_FOLDER}/target/release/"
|
|
NIX_RELEASE="${REPO_FOLDER}/result/bin/"
|
|
PATH="${GARAGE_DEBUG}:${GARAGE_RELEASE}:${NIX_RELEASE}:$PATH"
|
|
|
|
sleep 5
|
|
RETRY=120
|
|
until garage -c /tmp/config.1.toml status 2>&1|grep -q HEALTHY ; do
|
|
(( RETRY-- ))
|
|
if (( RETRY <= 0 )); then
|
|
echo "garage did not start in time, failing."
|
|
exit 1
|
|
fi
|
|
echo "cluster starting..."
|
|
sleep 1
|
|
done
|
|
|
|
garage -c /tmp/config.1.toml status \
|
|
| grep 'NO ROLE' \
|
|
| grep -Po '^[0-9a-f]+' \
|
|
| while read id; do
|
|
garage -c /tmp/config.1.toml layout assign $id -z dc1 -c 1
|
|
done
|
|
|
|
garage -c /tmp/config.1.toml layout apply --version 1
|