aboutsummaryrefslogtreecommitdiff
path: root/script/dev-cluster.sh
diff options
context:
space:
mode:
authorAlex <alex@adnab.me>2020-11-20 23:51:24 +0100
committerAlex <alex@adnab.me>2020-11-20 23:51:24 +0100
commit5dc304ac41c2ae0699fbdd56117b60c517a1ad39 (patch)
tree8eb7428d443a19dbe1d9995e833151eb79da74d2 /script/dev-cluster.sh
parent2dc9a4802279a0b7e742f8cf2e2cc85956bb7f83 (diff)
parent98e20a5898602d7312093246cb32ef39e619bbc5 (diff)
downloadgarage-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-xscript/dev-cluster.sh57
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