2022-01-12 19:04:55 +01:00
|
|
|
#!/usr/bin/env bash
|
2020-11-15 14:43:23 +01:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
SCRIPT_FOLDER="`dirname \"$0\"`"
|
|
|
|
REPO_FOLDER="${SCRIPT_FOLDER}/../"
|
|
|
|
GARAGE_DEBUG="${REPO_FOLDER}/target/debug/"
|
|
|
|
GARAGE_RELEASE="${REPO_FOLDER}/target/release/"
|
2021-10-04 18:27:57 +02:00
|
|
|
NIX_RELEASE="${REPO_FOLDER}/result/bin/"
|
|
|
|
PATH="${GARAGE_DEBUG}:${GARAGE_RELEASE}:${NIX_RELEASE}:$PATH"
|
2020-11-15 14:43:23 +01:00
|
|
|
FANCYCOLORS=("41m" "42m" "44m" "45m" "100m" "104m")
|
|
|
|
|
|
|
|
export RUST_BACKTRACE=1
|
2022-11-08 15:13:37 +01:00
|
|
|
export RUST_LOG=garage=info,garage_api=debug
|
2020-11-15 14:43:23 +01:00
|
|
|
MAIN_LABEL="\e[${FANCYCOLORS[0]}[main]\e[49m"
|
|
|
|
|
2023-09-27 13:38:17 +02:00
|
|
|
if [ -z "$GARAGE_BIN" ]; then
|
|
|
|
GARAGE_BIN=$(which garage || exit 1)
|
|
|
|
echo -en "${MAIN_LABEL} Found garage at: ${GARAGE_BIN}\n"
|
|
|
|
else
|
|
|
|
echo -en "${MAIN_LABEL} Using garage binary at: ${GARAGE_BIN}\n"
|
|
|
|
fi
|
|
|
|
$GARAGE_BIN --version
|
2020-11-20 23:50:23 +01:00
|
|
|
|
2021-10-19 16:16:10 +02:00
|
|
|
NETWORK_SECRET="$(openssl rand -hex 32)"
|
|
|
|
|
|
|
|
|
|
|
|
# <<<<<<<<< BEGIN FOR LOOP ON NODES
|
2020-11-15 14:43:23 +01:00
|
|
|
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"
|
2023-09-27 13:38:17 +02:00
|
|
|
db_engine = "lmdb"
|
2020-11-15 14:43:23 +01:00
|
|
|
data_dir = "/tmp/garage-data-$count"
|
2021-02-17 19:30:31 +01:00
|
|
|
rpc_bind_addr = "0.0.0.0:$((3900+$count))" # the port other Garage nodes will use to talk to this node
|
2021-10-19 16:16:10 +02:00
|
|
|
rpc_public_addr = "127.0.0.1:$((3900+$count))"
|
|
|
|
bootstrap_peers = []
|
2021-05-28 12:36:22 +02:00
|
|
|
replication_mode = "3"
|
2021-10-19 16:16:10 +02:00
|
|
|
rpc_secret = "$NETWORK_SECRET"
|
2020-11-15 14:43:23 +01:00
|
|
|
|
|
|
|
[s3_api]
|
2021-02-17 19:30:31 +01:00
|
|
|
api_bind_addr = "0.0.0.0:$((3910+$count))" # the S3 API port, HTTP without TLS. Add a reverse proxy for the TLS part.
|
2020-11-15 14:43:23 +01:00
|
|
|
s3_region = "garage" # set this to anything. S3 API calls will fail if they are not made against the region set here.
|
2022-02-01 17:55:14 +01:00
|
|
|
root_domain = ".s3.garage.localhost"
|
2020-11-15 14:43:23 +01:00
|
|
|
|
|
|
|
[s3_web]
|
2021-02-17 19:30:31 +01:00
|
|
|
bind_addr = "0.0.0.0:$((3920+$count))"
|
2022-02-01 17:55:14 +01:00
|
|
|
root_domain = ".web.garage.localhost"
|
2020-11-19 15:10:04 +01:00
|
|
|
index = "index.html"
|
2021-09-28 08:57:20 +02:00
|
|
|
|
2022-02-22 15:25:13 +01:00
|
|
|
[admin]
|
|
|
|
api_bind_addr = "0.0.0.0:$((9900+$count))"
|
2020-11-15 14:43:23 +01:00
|
|
|
EOF
|
|
|
|
|
|
|
|
echo -en "$LABEL configuration written to $CONF_PATH\n"
|
|
|
|
|
2023-09-27 13:38:17 +02:00
|
|
|
($GARAGE_BIN -c /tmp/config.$count.toml server 2>&1|while read r; do echo -en "$LABEL $r\n"; done) &
|
2021-10-21 17:19:18 +02:00
|
|
|
done
|
|
|
|
# >>>>>>>>>>>>>>>> END FOR LOOP ON NODES
|
|
|
|
|
2021-04-28 11:35:10 +02:00
|
|
|
if [ -z "$SKIP_HTTPS" ]; then
|
|
|
|
echo -en "$LABEL Starting dummy HTTPS reverse proxy\n"
|
|
|
|
mkdir -p /tmp/garagessl
|
|
|
|
openssl req \
|
|
|
|
-new \
|
|
|
|
-x509 \
|
|
|
|
-keyout /tmp/garagessl/test.key \
|
|
|
|
-out /tmp/garagessl/test.crt \
|
|
|
|
-nodes \
|
|
|
|
-subj "/C=XX/ST=XX/L=XX/O=XX/OU=XX/CN=localhost/emailAddress=X@X.XX" \
|
|
|
|
-addext "subjectAltName = DNS:localhost, IP:127.0.0.1"
|
|
|
|
cat /tmp/garagessl/test.key /tmp/garagessl/test.crt > /tmp/garagessl/test.pem
|
|
|
|
socat openssl-listen:4443,reuseaddr,fork,cert=/tmp/garagessl/test.pem,verify=0 tcp4-connect:localhost:3911 &
|
|
|
|
fi
|
|
|
|
|
2021-10-19 16:16:10 +02:00
|
|
|
sleep 3
|
|
|
|
# Establish connections between nodes
|
|
|
|
for count in $(seq 1 3); do
|
2023-09-27 13:38:17 +02:00
|
|
|
NODE=$($GARAGE_BIN -c /tmp/config.$count.toml node id -q)
|
2021-10-19 16:16:10 +02:00
|
|
|
for count2 in $(seq 1 3); do
|
2023-09-27 13:38:17 +02:00
|
|
|
$GARAGE_BIN -c /tmp/config.$count2.toml node connect $NODE
|
2021-10-19 16:16:10 +02:00
|
|
|
done
|
2020-11-15 14:43:23 +01:00
|
|
|
done
|
|
|
|
|
2021-10-04 18:27:57 +02:00
|
|
|
RETRY=120
|
2023-09-27 13:38:17 +02:00
|
|
|
until $GARAGE_BIN -c /tmp/config.1.toml status 2>&1|grep -q HEALTHY ; do
|
2021-10-04 18:27:57 +02:00
|
|
|
(( RETRY-- ))
|
|
|
|
if (( RETRY <= 0 )); then
|
|
|
|
echo -en "${MAIN_LABEL} Garage did not start"
|
|
|
|
exit 1
|
|
|
|
fi
|
2020-11-15 14:43:23 +01:00
|
|
|
echo -en "${MAIN_LABEL} cluster starting...\n"
|
|
|
|
sleep 1
|
|
|
|
done
|
2021-10-19 16:16:10 +02:00
|
|
|
|
2020-11-15 14:43:23 +01:00
|
|
|
echo -en "${MAIN_LABEL} cluster started\n"
|
|
|
|
|
|
|
|
wait
|