diff options
author | Alex <alex@adnab.me> | 2020-11-20 23:51:24 +0100 |
---|---|---|
committer | Alex <alex@adnab.me> | 2020-11-20 23:51:24 +0100 |
commit | 5dc304ac41c2ae0699fbdd56117b60c517a1ad39 (patch) | |
tree | 8eb7428d443a19dbe1d9995e833151eb79da74d2 /script/dev-cluster.sh | |
parent | 2dc9a4802279a0b7e742f8cf2e2cc85956bb7f83 (diff) | |
parent | 98e20a5898602d7312093246cb32ef39e619bbc5 (diff) | |
download | garage-5dc304ac41c2ae0699fbdd56117b60c517a1ad39.tar.gz garage-5dc304ac41c2ae0699fbdd56117b60c517a1ad39.zip |
Merge pull request 'Add more scripts to ease Garage's development' (#17) from feature/new-script into master
Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/17
Diffstat (limited to 'script/dev-cluster.sh')
-rwxr-xr-x | script/dev-cluster.sh | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/script/dev-cluster.sh b/script/dev-cluster.sh new file mode 100755 index 00000000..cfe9be0d --- /dev/null +++ b/script/dev-cluster.sh @@ -0,0 +1,57 @@ +#!/bin/bash + +set -e + +SCRIPT_FOLDER="`dirname \"$0\"`" +REPO_FOLDER="${SCRIPT_FOLDER}/../" +GARAGE_DEBUG="${REPO_FOLDER}/target/debug/" +GARAGE_RELEASE="${REPO_FOLDER}/target/release/" +PATH="${GARAGE_DEBUG}:${GARAGE_RELEASE}:$PATH" +FANCYCOLORS=("41m" "42m" "44m" "45m" "100m" "104m") + +export RUST_BACKTRACE=1 +export RUST_LOG=garage=info +MAIN_LABEL="\e[${FANCYCOLORS[0]}[main]\e[49m" + +WHICH_GARAGE=$(which garage || exit 1) +echo -en "${MAIN_LABEL} Found garage at: ${WHICH_GARAGE}\n" + +for count in $(seq 1 3); do +CONF_PATH="/tmp/config.$count.toml" +LABEL="\e[${FANCYCOLORS[$count]}[$count]\e[49m" + +cat > $CONF_PATH <<EOF +block_size = 1048576 # objects are split in blocks of maximum this number of bytes +metadata_dir = "/tmp/garage-meta-$count" +data_dir = "/tmp/garage-data-$count" +rpc_bind_addr = "127.0.0.$count:3901" # the port other Garage nodes will use to talk to this node +bootstrap_peers = [ + "127.0.0.1:3901", + "127.0.0.2:3901", + "127.0.0.3:3901" +] +max_concurrent_rpc_requests = 12 +data_replication_factor = 3 +meta_replication_factor = 3 +meta_epidemic_fanout = 3 + +[s3_api] +api_bind_addr = "127.0.0.$count:3900" # the S3 API port, HTTP without TLS. Add a reverse proxy for the TLS part. +s3_region = "garage" # set this to anything. S3 API calls will fail if they are not made against the region set here. + +[s3_web] +bind_addr = "127.0.0.$count:3902" +EOF + +echo -en "$LABEL configuration written to $CONF_PATH\n" + +(garage server -c /tmp/config.$count.toml 2>&1|while read r; do echo -en "$LABEL $r\n"; done) & +done + +until garage status 2>&1|grep -q Healthy ; do + echo -en "${MAIN_LABEL} cluster starting...\n" + sleep 1 +done +echo -en "${MAIN_LABEL} cluster started\n" + +wait |