Blob Blame History Raw
#!/bin/sh

#
# configurable parameters
# in order to change parameter add PARAMETER_NAME=VALUE before running the script.
#---------------------------------------------------

PPS=${PPS:-"100 1000 10000 50000 125000 500000 1000000 2000000 max"}
#2048 4096 8192 16384 32768 65536"}
M_SIZE=${M_SIZE:-"12 32 64 128 192 256 512 768 1024 1460"}
FD_NUMBER=${FD_NUMBER:-"1 2 5 10 25 50 100 250 500"}
#1000 25000 5000 10000
LOOP=${LOOP:-"1"}
SOCKPERF=${SOCKPERF:-sockperf}
DURATION=${DURATION:-30}
VMA_SELECT_POLL_VAL=${VMA_SELECT_POLL_VAL:-"-1 0 1000 1000000"}
VMA_RX_POLL_VAL=${VMA_RX_POLL_VAL:-"-1"}
VMA_ENV_FLAGS=${VMA_ENV_FLAGS:-"LD_PRELOAD=libvma.so"}
IOMUX_TYPE=${IOMUX_TYPE:-"s p e"}
SERVER_FLAG=${SERVER_FLAG:-" "}
CLIENT_FLAG=${CLIENT_FLAG:=" "}
TEST=${TEST:-"pp_test tp_test tp_udp_mc_imux_test pp_udp_mc_imux_test pp_tcp_imux_test pp_udp_uc_imux_test"}
#----to do---need to add tcp_imux uc_imux

#taskset -c 4,5,6 env

function run_latancy_test
{
#good for ping pong or under load test
#1 - flags
#2 - env_flags
	env ${2} ${SOCKPERF} ${1} ${CLIENT_FLAG} | egrep "Latency|dropped|std-dev|50.00 =|<MAX>|<MIN>|99.99 =|observations"| awk '{" "}; {if ($3=="Latency") printf "%4.3f ",$5 ; if ($4 ~ "std-dev") printf "%s ",$4; if ($4=="50.00") printf "%4.3f ",$6;if ($4=="99.99") printf "%4.3f ",$6; if ($3=="<MAX>") printf "%4.3f ", $6 ; if ($3=="dropped") printf "%s %s %s ", $6 , $11 , $16; if ($3=="<MIN>") printf "%4.3f ", $6 ; if ($9=="observations") printf "%d ", $3}' >> ${OUT_FILE}
	echo " " >> ${OUT_FILE}
	sleep 1
}

function run_throughput_test
{
	#1 - flags
	#2 - env_flags
	env ${2} ${SOCKPERF} tp ${1} ${CLIENT_FLAG}|egrep "Summary:"| awk '{" "} {if ($3=="Message") printf "%d ",$6 ; if ($3=="BandWidth") printf "%4.3f ",$5}'  >> ${OUT_FILE}
	sleep 1
}

function create_feed_file_uni()
{
	#1 size
	#2 ip
	#3 port
	#4 feed file
	port=$1-1
	let port=port+$3
	until [ $port -lt $3 ]; do
		echo "$2:$port" >> $4
		let port-=1
	done
}
function create_feed_file_tcp()
{
	#1 size
	#2 ip
	#3 port
	#4 feed file

#	echo "T:$2:$3" >> "$4_sr"
	port=$1-1
	let port=port+$3
	until [ $port -lt $3 ]; do
		echo "T:$2:$3" >> $4
		let port-=1
	done
}

# different addresses
function create_feed_file_multi()
{
	#1 size
	#2 feed file
	port=10005
	ip_1=224
	ip_2=4
	ip_3=1
	ip_4=3
	counter=0
	while [ $counter -lt $1 ]; do
		echo "$ip_1.$ip_2.$ip_3.$ip_4:$port" >> $2
		let counter=counter+1
		let port=port+1
		let ip_4=ip_4+1
		if [ $ip_4 = 255 ]; then
			let ip_3=ip_3+1
			ip_4=3
		fi
	done
}

#create_feed_file_uni 10 17.17.17.10 10005 ${FEED_FILE}
#create_feed_file_tcp 10 17.17.17.10 10005 ${FEED_FILE}
#cat "${FEED_FILE}_sr"
#create_feed_file_multi 1000 ${FEED_FILE}



#--------------------------------------TP-MC-IMUX-------------------
function tp_udp_mc_imux_test()
{
	echo "TP measurement UDP MC FEED_FILE" >> ${OUT_FILE}
	echo "VMA_SELECT_POLL Imoux_type Fd_number Message-size PPS Message-rate bandwidth" >> ${OUT_FILE}

	for imoux_type in ${IOMUX_TYPE}; do
		for fd_num in ${FD_NUMBER}; do
			rm ${FEED_FILE}
			create_feed_file_multi ${fd_num} ${FEED_FILE}
			scp "${FEED_FILE}" "${SERVER}:${FEED_FILE}"

			for select_poll in ${VMA_SELECT_POLL_VAL}; do
				ssh $SERVER pkill -f sockperf
				sleep 1
				ssh $SERVER env VMA_RX_POLL="-1" VMA_SELECT_POLL=${select_poll} ${VMA_ENV_FLAGS} ${SOCKPERF} server -f ${FEED_FILE} -F ${imoux_type} ${SERVER_FLAG} &
				sleep 5
				for pps_num in ${PPS}; do
					for j in ${M_SIZE}; do
						echo -n "${select_poll} ${imoux_type} ${fd_num} $j ${pps_num} " >> ${OUT_FILE}
						run_throughput_test "-m ${j} --mps ${pps_num} -t ${DURATION} -f ${FEED_FILE} -F ${imoux_type}" "VMA_SELECT_POLL=${select_poll} VMA_RX_POLL=-1 ${VMA_ENV_FLAGS}"
					done
				done
			done
		done
		rm ${FEED_FILE}
	done
	echo " " >> ${OUT_FILE}
}

#--------------------------------------TP---------------------
function tp_test()
{
	echo "TP measurement UDP MC" >> ${OUT_FILE}
	echo "VMA_RX_POLL Message-size PPS Message-rate bandwidth" >> ${OUT_FILE}

	for rx_poll in ${VMA_RX_POLL_VAL}; do
		ssh $SERVER pkill -f sockperf
		sleep 1
		ssh $SERVER env VMA_SELECT_POLL="-1" VMA_RX_POLL=${rx_poll} ${VMA_ENV_FLAGS} ${SOCKPERF} server -i ${SERVER_ADD} ${SERVER_FLAG} &
		sleep 5
		for pps_num in ${PPS}; do
			for j in ${M_SIZE}; do
				echo -n "${rx_poll} $j ${pps_num} " >> ${OUT_FILE}
				run_throughput_test "-m ${j} --mps ${pps_num} -t ${DURATION} -i ${SERVER_ADD}" "VMA_SELECT_POLL=-1 VMA_RX_POLL=${rx_poll} ${VMA_ENV_FLAGS}"
			done
		done
	done
	echo " " >> ${OUT_FILE}
}


#--------------------------------------PP-MC-IMUX-------------------
function pp_udp_mc_imux_test()
{
	echo "Latency Ping-pong measurement UDP MC FEED_FILE" >> ${OUT_FILE}
	echo "VMA_SELECT_POLL Imoux_type Fd_number Message-size PPS std-dev dropped-messages duplicated-messages out-of-order-messages Average_Latency Total_observations Max_Latency 99%_percentile 50%_percentile Min_Latency" >> ${OUT_FILE}

	for imoux_type in ${IOMUX_TYPE}; do
		for fd_num in ${FD_NUMBER}; do
			rm ${FEED_FILE}
			create_feed_file_multi ${fd_num} ${FEED_FILE}
			scp "${FEED_FILE}" "${SERVER}:${FEED_FILE}"

			for select_poll in ${VMA_SELECT_POLL_VAL}; do
				ssh $SERVER pkill -f sockperf
				sleep 1
				ssh $SERVER env VMA_RX_POLL="-1" VMA_SELECT_POLL=${select_poll} ${VMA_ENV_FLAGS} ${SOCKPERF} server -f ${FEED_FILE} -F ${imoux_type} ${SERVER_FLAG} &
				sleep 5
				for pps_num in ${PPS}; do
					for j in ${M_SIZE}; do
						echo -n "${select_poll} ${imoux_type} ${fd_num} $j ${pps_num} " >> ${OUT_FILE}
						run_latancy_test "pp -m ${j} --mps ${pps_num} -t ${DURATION} -f ${FEED_FILE} -F ${imoux_type}" "VMA_SELECT_POLL=${select_poll} VMA_RX_POLL=-1 ${VMA_ENV_FLAGS}"
					done
				done
			done
		done
		rm ${FEED_FILE}
	done
	echo " " >> ${OUT_FILE}
}

#--------------------------------------PP---------------------
function pp_test()
{
	echo "Latency Ping-pong measurement UDP" >> ${OUT_FILE}
	echo "VMA_RX_POLL Message-size PPS std-dev dropped-messages duplicated-messages out-of-order-messages Average_Latency Total_observations Max_Latency 99%_percentile 50%_percentile Min_Latency" >> ${OUT_FILE}

	for rx_poll in ${VMA_RX_POLL_VAL}; do
		ssh $SERVER pkill -f sockperf
		sleep 1
		ssh $SERVER env VMA_SELECT_POLL="-1" VMA_RX_POLL=${rx_poll} ${VMA_ENV_FLAGS} ${SOCKPERF} server -i ${SERVER_ADD} ${SERVER_FLAG} &
		sleep 5
		for pps_num in ${PPS}; do
			for j in ${M_SIZE}; do
				echo -n "${rx_poll} $j ${pps_num} " >> ${OUT_FILE}
				run_latancy_test "pp -m ${j} --mps ${pps_num} -t ${DURATION} -i ${SERVER_ADD}" "VMA_SELECT_POLL=-1 VMA_RX_POLL=${rx_poll} ${VMA_ENV_FLAGS}"
			done
		done
	done
	echo " " >> ${OUT_FILE}
}


#--------------------------------------PP-TCP-IMUX-------------------
function pp_tcp_imux_test()
{
	echo "Latency Ping-pong measurement TCP FEED_FILE" >> ${OUT_FILE}
	echo "VMA_SELECT_POLL Imoux_type Fd_number Message-size PPS std-dev dropped-messages duplicated-messages out-of-order-messages Average_Latency Total_observations Max_Latency 99%_percentile 50%_percentile Min_Latency" >> ${OUT_FILE}

	for imoux_type in ${IOMUX_TYPE}; do
		for fd_num in ${FD_NUMBER}; do
			rm ${FEED_FILE}
			create_feed_file_tcp ${fd_num} ${SERVER_ADD} 10005 ${FEED_FILE}
			scp "${FEED_FILE}" "${SERVER}:${FEED_FILE}"

			for select_poll in ${VMA_SELECT_POLL_VAL}; do
				ssh $SERVER pkill -f sockperf
				sleep 1
				ssh $SERVER env VMA_RX_POLL="-1" VMA_SELECT_POLL=${select_poll} ${VMA_ENV_FLAGS} ${SOCKPERF} server -f ${FEED_FILE} -F ${imoux_type} ${SERVER_FLAG} &
				sleep 5
				for pps_num in ${PPS}; do
					for j in ${M_SIZE}; do
						echo -n "${select_poll} ${imoux_type} ${fd_num} $j ${pps_num} " >> ${OUT_FILE}
						run_latancy_test "pp -m ${j} --mps ${pps_num} -t ${DURATION} -f ${FEED_FILE} -F ${imoux_type}" "VMA_SELECT_POLL=${select_poll} VMA_RX_POLL=-1 ${VMA_ENV_FLAGS}"
					done
				done
			done
		done
		rm ${FEED_FILE}
	done
	echo " " >> ${OUT_FILE}
}


#--------------------------------------PP-UDP-UC-IMUX-------------------
function pp_udp_uc_imux_test()
{
	echo "Latency Ping-pong measurement UDP UC FEED_FILE" >> ${OUT_FILE}
	echo "VMA_SELECT_POLL Imoux_type Fd_number Message-size PPS std-dev dropped-messages duplicated-messages out-of-order-messages Average_Latency Total_observations Max_Latency 99%_percentile 50%_percentile Min_Latency" >> ${OUT_FILE}

	for imoux_type in ${IOMUX_TYPE}; do
		for fd_num in ${FD_NUMBER}; do
			rm ${FEED_FILE}
			create_feed_file_uni ${fd_num} ${SERVER_ADD} 10005 ${FEED_FILE}
			scp "${FEED_FILE}" "${SERVER}:${FEED_FILE}"

			for select_poll in ${VMA_SELECT_POLL_VAL}; do
				ssh $SERVER pkill -f sockperf
				sleep 1
				ssh $SERVER env VMA_RX_POLL="-1" VMA_SELECT_POLL=${select_poll} ${VMA_ENV_FLAGS} ${SOCKPERF} server -f ${FEED_FILE} -F ${imoux_type} ${SERVER_FLAG} &
				sleep 5
				for pps_num in ${PPS}; do
					for j in ${M_SIZE}; do
						echo -n "${select_poll} ${imoux_type} ${fd_num} $j ${pps_num} " >> ${OUT_FILE}
						run_latancy_test "pp -m ${j} --mps ${pps_num} -t ${DURATION} -f ${FEED_FILE} -F ${imoux_type}" "VMA_SELECT_POLL=${select_poll} VMA_RX_POLL=-1 ${VMA_ENV_FLAGS}"
					done
				done
			done
		done
		rm ${FEED_FILE}
	done
	echo " " >> ${OUT_FILE}
}

#-----------------------------------main-----------------------------------------------

echo ""
echo "Usahge: $0 <name of remote host> <ip of remote host> <output_file.csv>"
echo ""
echo "to change script parameter write: >> PARAMETER_NAME=VALUE $0"
echo ""
echo "chopse test - TEST=test_name $0 ..."
for start_test in ${TEST}; do
	echo $start_test
done
echo ""
echo "script parameter:"
echo "PPS - value:              	${PPS}"
echo "M_SIZE - value:               ${M_SIZE}"
echo "FD_NUMBER - value:            ${FD_NUMBER}"
echo "LOOP - value:                 ${LOOP}"
echo "SOCKPERF - value:             ${SOCKPERF}"
echo "DURATION - value:             ${DURATION}"
echo "VMA_SELECT_POLL_VAL - value:  ${VMA_SELECT_POLL_VAL}"
echo "SERVER_FLAG - value:			${SERVER_FLAG}"
echo "CLIENT_FLAG - value:			${CLIENT_FLAG}"
echo "VMA_RX_POLL_VAL - value:      ${VMA_RX_POLL_VAL}"
echo "VMA_ENV_FLAGS - value:        ${VMA_ENV_FLAGS}"
echo "IOMUX_TYPE - value:			${IOMUX_TYPE}"

if [ $# -ne 3 ]; then
	exit 
else
	#echo "config	print all configurable parameters"
	echo "output will be print to ${3}"
fi

SERVER=${1}
SERVER_ADD=${2}
OUT_FILE=${3}
FEED_FILE="/tmp/feed_file"

for start_test in ${TEST}; do
	$start_test
done

exit