solana/net/init-metrics.sh

94 lines
2.0 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
set -e
here=$(dirname "$0")
# shellcheck source=net/common.sh
source "$here"/common.sh
usage() {
exitcode=0
if [[ -n "$1" ]]; then
exitcode=1
echo "Error: $*"
fi
cat <<EOF
usage: $0 [-e] [-d] [-c database_name] [username]
Creates a testnet dev metrics database
username InfluxDB user with access to create a new database
-c Manually specify a database to create, rather than read from config file
-d Delete the database instead of creating it
2018-09-06 09:29:56 -07:00
-e Assume database already exists and SOLANA_METRICS_CONFIG is
defined in the environment already
EOF
exit $exitcode
}
2018-09-06 09:29:56 -07:00
useEnv=false
delete=false
createWithoutConfig=false
2019-03-25 16:27:59 -07:00
host="https://metrics.solana.com:8086"
while getopts "hdec:" opt; do
case $opt in
h|\?)
usage
exit 0
;;
c)
createWithoutConfig=true
netBasename=$OPTARG
;;
d)
2018-09-03 21:15:55 -07:00
delete=true
;;
2018-09-06 09:29:56 -07:00
e)
useEnv=true
;;
*)
2018-11-07 10:35:08 -08:00
usage "unhandled option: $opt"
;;
esac
done
shift $((OPTIND - 1))
2018-09-06 09:29:56 -07:00
if $useEnv; then
[[ -n $SOLANA_METRICS_CONFIG ]] ||
2018-11-07 10:35:08 -08:00
usage "SOLANA_METRICS_CONFIG is not defined in the environment"
2018-09-06 09:29:56 -07:00
else
username=$1
[[ -n "$username" ]] || usage "username not specified"
2018-09-06 09:29:56 -07:00
read -rs -p "InfluxDB password for $username: " password
[[ -n $password ]] || { echo "Password not specified"; exit 1; }
echo
password="$(urlencode "$password")"
if ! $createWithoutConfig; then
loadConfigFile
fi
2018-09-06 09:29:56 -07:00
query() {
echo "$*"
set -x
2018-09-06 09:29:56 -07:00
curl -XPOST \
2019-03-25 16:27:59 -07:00
"$host/query?u=${username}&p=${password}" \
2018-09-06 09:29:56 -07:00
--data-urlencode "q=$*"
}
query "DROP DATABASE \"$netBasename\""
! $delete || exit 0
query "CREATE DATABASE \"$netBasename\""
query "ALTER RETENTION POLICY autogen ON \"$netBasename\" DURATION 7d"
query "GRANT READ ON \"$netBasename\" TO \"ro\""
query "GRANT WRITE ON \"$netBasename\" TO \"scratch_writer\""
2019-03-25 16:27:59 -07:00
SOLANA_METRICS_CONFIG="host=$host,db=$netBasename,u=scratch_writer,p=topsecret"
2018-09-06 09:29:56 -07:00
fi
2018-09-06 09:29:56 -07:00
echo "export SOLANA_METRICS_CONFIG=\"$SOLANA_METRICS_CONFIG\"" >> "$configFile"
exit 0