55 lines
1.2 KiB
Plaintext
55 lines
1.2 KiB
Plaintext
|
#/bin/bash
|
||
|
|
||
|
# Starts a Hydrabadger node
|
||
|
# =========================
|
||
|
#
|
||
|
# Optional environment variables:
|
||
|
#
|
||
|
# * HYDRABADGER_LOG_ADDTL:
|
||
|
#
|
||
|
# Appends additional logging args (debug, trace, filters, etc.).
|
||
|
#
|
||
|
# * HYDRABADGER_RELEASE:
|
||
|
#
|
||
|
# Builds in debug mode if `HYDRABADGER_RELEASE` == `0` or `false`.
|
||
|
# Slows down output and makes reading log easier.
|
||
|
#
|
||
|
#
|
||
|
|
||
|
let HOST_ID=$1
|
||
|
let PEER_0_ID=$HOST_ID==0?$HOST_ID+2:$HOST_ID-1
|
||
|
let PEER_1_ID=$HOST_ID+1
|
||
|
|
||
|
printf -v HOST_PORT "3%03d" $HOST_ID
|
||
|
printf -v PEER_0_PORT "3%03d" $PEER_0_ID
|
||
|
printf -v PEER_1_PORT "3%03d" $PEER_1_ID
|
||
|
|
||
|
HYDRABADGER_LOG=peer_node::hydrabadger=error,warn,info,$HYDRABADGER_LOG_ADDTL
|
||
|
|
||
|
if [[ $HYDRABADGER_RELEASE ]]
|
||
|
then
|
||
|
case "$HYDRABADGER_RELEASE" in
|
||
|
0|false) RELEASE=""; DIRECTORY="debug" ;;
|
||
|
*) RELEASE="--release"; DIRECTORY="release" ;;
|
||
|
esac
|
||
|
else
|
||
|
RELEASE="--release"
|
||
|
DIRECTORY="release"
|
||
|
fi
|
||
|
|
||
|
cargo build $RELEASE
|
||
|
|
||
|
# printf "\nLimiting process memory limit to 400MiB...\n\n"
|
||
|
# ulimit -Sv 400000
|
||
|
|
||
|
mkdir tmp
|
||
|
|
||
|
bash -c "\
|
||
|
HYDRABADGER_LOG=$HYDRABADGER_LOG ltrace target/$DIRECTORY/peer_node \
|
||
|
-b localhost:$HOST_PORT \
|
||
|
-r localhost:$PEER_0_PORT \
|
||
|
-r localhost:$PEER_1_PORT\
|
||
|
$2 $3 $4 $5 $6 $7 $8 \
|
||
|
2>&1 | tee tmp/ltrace_peer_node_$1.log
|
||
|
"
|