mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-23 19:56:18 -08:00
8b0cda8bb3
Co-authored-by: Nicolás Pazos <npazosmendez@gmail.com> Signed-off-by: Callum Styan <callumstyan@gmail.com> Signed-off-by: Nicolás Pazos <npazosmendez@gmail.com>
93 lines
3.1 KiB
Bash
Executable file
93 lines
3.1 KiB
Bash
Executable file
#!/bin/sh
|
|
set -e
|
|
trap "trap - SIGTERM && kill -- -$$" SIGINT SIGTERM EXIT
|
|
|
|
# CONFIGURABLES
|
|
# ~~~~~~~~~~~~~
|
|
declare -a INSTANCES
|
|
# (sender,receiver) pairs to run: (sender_name; sender_flags; receiver_name; receiver_flags)
|
|
INSTANCES+=('sender-v1;;receiver-v1;')
|
|
INSTANCES+=('sender-v11-min32-optimized-varint;--remote-write-format 1;receiver-v11-min32-optimized-varint;--remote-write-format 1')
|
|
INSTANCES+=('sender-v11-min64-fixed;--remote-write-format 2;receiver-v11-min64-fixed;--remote-write-format 2')
|
|
INSTANCES+=('sender-v11-min32-fixed;--remote-write-format 3;receiver-v11-min32-fixed;--remote-write-format 3')
|
|
INSTANCES+=('sender-v11-min-bytes;--remote-write-format 4;receiver-v11-min-bytes;--remote-write-format 4')
|
|
|
|
# ~~~~~~~~~~~~~
|
|
|
|
# append two ports to all instances
|
|
PROM_PORT=9090
|
|
for i in "${!INSTANCES[@]}"; do
|
|
INSTANCES[$i]="${INSTANCES[$i]};$PROM_PORT"
|
|
PROM_PORT=$((PROM_PORT+1))
|
|
INSTANCES[$i]="${INSTANCES[$i]};$PROM_PORT"
|
|
PROM_PORT=$((PROM_PORT+1))
|
|
done
|
|
|
|
# Check if all required variables are set
|
|
: "${CONTEXT:?}"
|
|
: "${NAMESPACE:?}"
|
|
|
|
BASE_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
|
|
|
TEMP_DIR=$(mktemp -d)
|
|
echo "Working on dir: $TEMP_DIR"
|
|
SCRAPE_CONFIGS=""
|
|
declare -a COMMANDS
|
|
PORT=40000
|
|
# Get all pods from namespace, create scrape configs and port forward them
|
|
while read pod ; do
|
|
COMMANDS+=("kubectl --context $CONTEXT -n $NAMESPACE port-forward $pod $PORT:http-metrics")
|
|
SCRAPE_CONFIGS="${SCRAPE_CONFIGS}
|
|
- job_name: '$pod'
|
|
static_configs:
|
|
- targets: ['localhost:$PORT']"
|
|
|
|
PORT=$((PORT+1))
|
|
done < <(kubectl --context $CONTEXT -n $NAMESPACE get pods | awk '{print $1}' | tail +2 )
|
|
|
|
|
|
# Run all prometheus instances and add them to the scrape configs
|
|
for instance in "${INSTANCES[@]}"
|
|
do
|
|
IFS=";" read -r -a arr <<< "${instance}"
|
|
|
|
sender="${arr[0]}"
|
|
sender_flags="${arr[1]}"
|
|
receiver="${arr[2]}"
|
|
receiver_flags="${arr[3]}"
|
|
sender_port="${arr[4]}"
|
|
receiver_port="${arr[5]}"
|
|
|
|
SCRAPE_CONFIGS="${SCRAPE_CONFIGS}
|
|
- job_name: '$sender'
|
|
static_configs:
|
|
- targets: ['localhost:$sender_port']
|
|
- job_name: '$receiver'
|
|
static_configs:
|
|
- targets: ['localhost:$receiver_port']"
|
|
|
|
COMMANDS+=("./prometheus --config.file=$TEMP_DIR/$sender.yml --web.listen-address=0.0.0.0:$sender_port --storage.tsdb.path=$TEMP_DIR/tsdb/$sender/data/ $sender_flags 2>&1 | awk '{print \"[$sender]\",\$0}'")
|
|
COMMANDS+=("./prometheus --config.file=$TEMP_DIR/$receiver.yml --web.listen-address=0.0.0.0:$receiver_port --storage.tsdb.path=$TEMP_DIR/tsdb/$receiver/data/ $receiver_flags --web.enable-remote-write-receiver 2>&1 | awk '{print \"[$receiver]\",\$0}'")
|
|
done
|
|
|
|
# Create the yml configs for the prometheus instances
|
|
for instance in "${INSTANCES[@]}"
|
|
do
|
|
IFS=";" read -r -a arr <<< "${instance}"
|
|
export SENDER_NAME="${arr[0]}"
|
|
export RECEIVER_NAME="${arr[2]}"
|
|
export REMOTE_WRITE_PORT="${arr[5]}"
|
|
export SCRAPE_CONFIGS="$SCRAPE_CONFIGS"
|
|
envsubst < "$BASE_DIR/receiver-template.yml" > "$TEMP_DIR/$RECEIVER_NAME.yml"
|
|
envsubst < "$BASE_DIR/sender-template.yml" > "$TEMP_DIR/$SENDER_NAME.yml"
|
|
done
|
|
|
|
# Actually run all commands
|
|
for cmd in "${COMMANDS[@]}"
|
|
do
|
|
eval $cmd &
|
|
done
|
|
|
|
echo Running...
|
|
read -r -d '' _ </dev/tty
|