2024-02-29 20:03:12 +01:00
|
|
|
#!/usr/bin/env bash
|
2018-10-22 18:33:03 +02:00
|
|
|
#
|
|
|
|
# Integration Infiniband test using villas-node.
|
|
|
|
#
|
|
|
|
# Author: Dennis Potter <dennis@dennispotter.eu>
|
2022-03-15 09:28:57 -04:00
|
|
|
# SPDX-FileCopyrightText: 2014-2023 Institute for Automation of Complex Power Systems, RWTH Aachen University
|
2022-07-04 18:20:03 +02:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2021-08-10 10:12:48 -04:00
|
|
|
set -e
|
|
|
|
|
2018-10-22 18:33:03 +02:00
|
|
|
# Settings
|
|
|
|
|
|
|
|
# ${NUM_VALUES}, ${RATE_SAMPLES}, and ${IB_MODES} may be a list.
|
|
|
|
|
2018-10-23 00:11:28 +02:00
|
|
|
NUM_VALUES=(8)
|
2018-10-22 18:33:03 +02:00
|
|
|
RATE_SAMPLES=(10)
|
|
|
|
TIME_TO_RUN=5
|
|
|
|
IB_MODES=("RC")
|
|
|
|
|
2021-09-22 10:27:01 +02:00
|
|
|
. ${SRCDIR}/tools/villas-helper.sh
|
|
|
|
|
2018-10-22 18:33:03 +02:00
|
|
|
# Check if user is superuser. SU is used for namespace
|
|
|
|
if [[ "$EUID" -ne 0 ]]; then
|
2024-02-29 21:54:10 +01:00
|
|
|
echo "Please run as root"
|
|
|
|
exit 99
|
2018-10-22 18:33:03 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Check whether cpuset cset command is availble
|
|
|
|
if [[ ! $(command -v cset) ]]; then
|
2024-02-29 21:54:10 +01:00
|
|
|
echo "Cset is not availble for root. Please install it: https://github.com/lpechacek/cpuset"
|
|
|
|
exit 99
|
2018-10-22 18:33:03 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Check if Infiniband card is present
|
|
|
|
if [[ ! $(lspci | grep Infiniband) ]]; then
|
2024-02-29 21:54:10 +01:00
|
|
|
echo "Did not find any Infiniband cards in system"
|
|
|
|
exit 99
|
2018-10-22 18:33:03 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Create list of configs and check whether they are valid
|
|
|
|
OIFS=$IFS; IFS=$'\n'; CONFIG_FILES=($(ls configs | sed -e "s/.conf//")); IFS=$OIFS;
|
|
|
|
|
|
|
|
NODETYPES=()
|
|
|
|
|
|
|
|
if [[ ! $1 ]]; then
|
2024-02-29 21:54:10 +01:00
|
|
|
echo "Please define for which node-type to run the script"
|
|
|
|
exit 1
|
2018-10-22 18:33:03 +02:00
|
|
|
elif [[ $1 == all ]]; then
|
2024-02-29 21:54:10 +01:00
|
|
|
echo "Benchmarking the following nodes:"
|
|
|
|
for NODETYPE in "${CONFIG_FILES[@]}"
|
|
|
|
do
|
|
|
|
echo ${NODETYPE}
|
|
|
|
NODETYPES+=(${NODETYPE})
|
|
|
|
done
|
2018-10-22 18:33:03 +02:00
|
|
|
|
|
|
|
else
|
2024-02-29 21:54:10 +01:00
|
|
|
FOUND=0
|
|
|
|
|
|
|
|
for NODETYPE in "${CONFIG_FILES[@]}"
|
|
|
|
do
|
|
|
|
if [[ $1 == ${NODETYPE} ]]; then
|
|
|
|
NODETYPES=$1
|
|
|
|
FOUND=1
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
if [[ ${FOUND} == 0 ]]; then
|
|
|
|
echo "Please define a valid node-type for which a config file is present in ./configs!"
|
|
|
|
exit 1
|
|
|
|
fi
|
2018-10-22 18:33:03 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
# SET PATHS
|
|
|
|
|
|
|
|
# Declare location of config files
|
|
|
|
CONFIG=$(mktemp /tmp/nodetype-benchmark-config-XXXX.conf)
|
|
|
|
CONFIG_TARGET=$(mktemp /tmp/nodetype-benchmark-config-target-XXXX.conf)
|
|
|
|
CONFIG_SOURCE=$(mktemp /tmp/nodetype-benchmark-config-source-XXXX.conf)
|
|
|
|
|
|
|
|
# Initialize counter
|
|
|
|
COUNT=0
|
|
|
|
|
|
|
|
# START OF LOOPS THROUGH CONFIGS
|
|
|
|
|
|
|
|
echo ${CONFIG_FILES[0]}
|
|
|
|
echo ${CONFIG_FILES[1]}
|
|
|
|
|
|
|
|
for NODETYPE in "${NODETYPES[@]}"
|
|
|
|
do
|
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# CREATE PATH CONFIG FILES
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# Set target and source config file, which is the same for both runs
|
2018-10-23 00:11:28 +02:00
|
|
|
cat > ${CONFIG_SOURCE} <<EOF
|
|
|
|
@include "${CONFIG//\/tmp\/}"
|
|
|
|
|
|
|
|
paths = (
|
2024-02-29 21:54:10 +01:00
|
|
|
{
|
|
|
|
in = "siggen",
|
|
|
|
out = ("source_node", "results_in"),
|
|
|
|
}
|
2018-10-23 00:11:28 +02:00
|
|
|
)
|
|
|
|
EOF
|
|
|
|
|
2018-10-22 18:33:03 +02:00
|
|
|
cat > ${CONFIG_TARGET} <<EOF
|
|
|
|
@include "${CONFIG//\/tmp\/}"
|
|
|
|
|
|
|
|
paths = (
|
2024-02-29 21:54:10 +01:00
|
|
|
{
|
|
|
|
in = "target_node",
|
|
|
|
out = "results_out",
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
original_sequence_no = true
|
|
|
|
}
|
2018-10-22 18:33:03 +02:00
|
|
|
)
|
|
|
|
EOF
|
2024-02-29 21:54:10 +01:00
|
|
|
# SPECIAL TREATMENT FOR SOME NODES
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# Some nodes require special treatment:
|
|
|
|
# * loopback node: target_node is identical to source_node
|
|
|
|
# * infiniband node: one node must be executed in a namespace
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# loopback
|
|
|
|
if [ "${NODETYPE}" == "loopback" ]; then
|
2018-10-23 00:11:28 +02:00
|
|
|
cat > ${CONFIG_TARGET} <<EOF
|
2018-10-22 18:33:03 +02:00
|
|
|
@include "${CONFIG//\/tmp\/}"
|
|
|
|
|
|
|
|
paths = (
|
2024-02-29 21:54:10 +01:00
|
|
|
{
|
|
|
|
in = "siggen",
|
|
|
|
out = ("source_node", "results_in"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
in = "source_node",
|
|
|
|
out = "results_out",
|
|
|
|
|
|
|
|
original_sequence_no = true
|
|
|
|
}
|
2018-10-22 18:33:03 +02:00
|
|
|
)
|
|
|
|
EOF
|
2024-02-29 21:54:10 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
# infiniband
|
|
|
|
if [ "${NODETYPE}" == "infiniband" ]; then
|
|
|
|
NAMESPACE_CMD='ip netns exec namespace0'
|
|
|
|
else
|
|
|
|
NAMESPACE_CMD=''
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# RUN THROUGH MODES
|
|
|
|
for IB_MODE in "${IB_MODES[@]}"
|
|
|
|
do
|
|
|
|
LOG_DIR=$(date +%Y%m%d_%H-%M-%S)_benchmark_${NODETYPE}_${IB_MODE}
|
|
|
|
|
|
|
|
for NUM_VALUE in "${NUM_VALUES[@]}"
|
|
|
|
do
|
|
|
|
for RATE_SAMPLE in "${RATE_SAMPLES[@]}"
|
|
|
|
do
|
|
|
|
NUM_SAMPLE=$((${RATE_SAMPLE} * ${TIME_TO_RUN}))
|
|
|
|
#TIME_TO_RUN=$((${NUM_SAMPLE} / ${RATE_SAMPLE}))
|
|
|
|
|
|
|
|
echo "#####"
|
|
|
|
echo "## START ${IB_MODE}"
|
|
|
|
echo "## NUM_VALUES: ${NUM_VALUE}"
|
|
|
|
echo "## RATE_SAMPLES: ${RATE_SAMPLE}"
|
|
|
|
echo "## NUM_SAMPLES: ${NUM_SAMPLE}"
|
|
|
|
|
|
|
|
# Set wrapper of config file
|
2018-10-22 18:33:03 +02:00
|
|
|
cat > ${CONFIG} <<EOF
|
|
|
|
logging = {
|
2024-02-29 21:54:10 +01:00
|
|
|
level = 0,
|
|
|
|
facilities = "all",
|
2018-10-22 18:33:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
http = {
|
2024-02-29 21:54:10 +01:00
|
|
|
enabled = false,
|
2018-10-22 18:33:03 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
nodes = {
|
2024-02-29 21:54:10 +01:00
|
|
|
siggen = {
|
|
|
|
type = "signal",
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
signal = "mixed",
|
|
|
|
values = ${NUM_VALUE},
|
|
|
|
frequency = 3,
|
|
|
|
rate = ${RATE_SAMPLE},
|
|
|
|
limit = ${NUM_SAMPLE},
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
monitor_missed = false
|
|
|
|
},
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
results_in = {
|
|
|
|
type = "file",
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
format = "csv",
|
|
|
|
uri = "${LOG_DIR}/$(printf "%03d" ${COUNT})_${IB_MODE}-${NUM_VALUE}-${RATE_SAMPLE}-${NUM_SAMPLE}_input.csv",
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
buffer_size = 500000000
|
|
|
|
},
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
results_out = {
|
|
|
|
type = "file",
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
format = "csv",
|
|
|
|
uri = "${LOG_DIR}/$(printf "%03d" ${COUNT})_${IB_MODE}-${NUM_VALUE}-${RATE_SAMPLE}-${NUM_SAMPLE}_output.csv",
|
2018-10-22 18:33:03 +02:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
buffer_size = 500000000
|
|
|
|
},
|
2018-10-22 18:33:03 +02:00
|
|
|
EOF
|
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
cat configs/${NODETYPE}.conf | sed -e "s/\${NUM_VALUE}/${NUM_VALUE}/" -e "s/\${IB_MODE}/${IB_MODE}/" >> ${CONFIG}
|
2018-10-22 18:33:03 +02:00
|
|
|
|
|
|
|
cat >> ${CONFIG} <<EOF
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# Start receiving node
|
|
|
|
VILLAS_LOG_PREFIX=$(colorize "[target] ") \
|
|
|
|
cset proc --set=real-time-0 --exec ../../build/src/villas-node -- ${CONFIG_TARGET} &
|
|
|
|
target_node_proc=$!
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# Wait for node to complete init
|
|
|
|
sleep 2
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
if [ ! "${NODETYPE}" == "loopback" ]; then
|
|
|
|
# Start sending pipe
|
|
|
|
VILLAS_LOG_PREFIX=$(colorize "[source] ") \
|
|
|
|
${NAMESPACE_CMD} cset proc --set=real-time-1 --exec ../../build/src/villas-node -- ${CONFIG_SOURCE} &
|
|
|
|
source_node_proc=$!
|
|
|
|
fi
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
sleep $((${TIME_TO_RUN} + 5))
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# Stop node
|
|
|
|
kill $target_node_proc
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
sleep 1
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
echo "## STOP ${IB_MODE}-${NUM_VALUE}-${RATE_SAMPLE}-${NUM_SAMPLE}"
|
|
|
|
echo ""
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
((COUNT++))
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
done
|
2024-02-29 20:03:12 +01:00
|
|
|
|
2024-02-29 21:54:10 +01:00
|
|
|
# Since this script will be executed as sudo we should chmod the
|
|
|
|
# log dir 777. Otherwise too many unnecessary 'sudo rm -rf' will be invoked.
|
|
|
|
chmod -R 777 ${LOG_DIR}
|
|
|
|
done
|
2018-10-22 18:33:03 +02:00
|
|
|
done
|
|
|
|
|
2024-02-29 20:03:12 +01:00
|
|
|
rm ${CONFIG} ${CONFIG_TARGET} ${CONFIG_SOURCE}
|
2018-10-22 18:33:03 +02:00
|
|
|
|
|
|
|
exit 0
|