Skip to content

Commit

Permalink
new scripts
Browse files Browse the repository at this point in the history
  • Loading branch information
UmakantKulkarni committed Dec 2, 2021
1 parent 75ba232 commit 162fdbf
Show file tree
Hide file tree
Showing 2 changed files with 379 additions and 136 deletions.
150 changes: 82 additions & 68 deletions getCpuVsQueue.sh
Original file line number Diff line number Diff line change
@@ -1,79 +1,93 @@
#!/usr/bin/env bash

for exp in Run4/* ;
commonTZ="MDT"
exp=/proj/sfcs-PG0/opt/Results

declare -a experimentDirAry=("Fully-Stateful" "Fully-Transactional-Stateless" "Amf-Smf-Share-Udsf" "Nonblocking-Api-Enabled")

for f1 in "${experimentDirAry[@]}"
do
echo "Working on $exp"
echo "Working on $exp/$f1"
echo " "
f1=`basename $exp`
for subexp in `seq 100 100 1000`
subexp=1000
if [[ $f1 == "Fully-Stateful" ]]; then
jarray=(1 2 3 4 5 6 7 8 9 10)
elif [[ $f1 == "Fully-Transactional-Stateless" ]]; then
jarray=(1 3 4 6 8)
elif [[ $f1 == "Amf-Smf-Share-Udsf" ]]; then
jarray=(1 2 4 5 7 8 9)
elif [[ $f1 == "Nonblocking-Api-Enabled" ]]; then
jarray=(1 2 3 4 7 8 9 10)
fi
for j in ${jarray[@]}
do
for j in `seq 0 1 10`
amfTopFile=$exp/$f1-$j/$subexp/top_data_node1.txt
topCpuOpFile=$exp/$f1-$j/$subexp/topCpuOp.csv
queueLenFile=$exp/$f1-$j/$subexp/queueLen.csv
rm -f $topCpuOpFile
rm -f $queueLenFile

echo "Working on $topCpuOpFile"
sjCount=$(cat $amfTopFile | grep systemd-journal | wc -l)
echo "UTC-Time, Time-Diff, CPU-Usage" >> $topCpuOpFile
timestamps=( $(cat $amfTopFile | grep 2021- | grep -o '\-\-.*' | cut -c 3-) )
if (( $sjCount < 5 )); then
timestamps=("${timestamps[@]:1}")
fi
cpusage=( $(cat $amfTopFile | grep open5gs-amfd | awk '{print $9}') )
basecpu="0.0"
k=0
for i in "${!cpusage[@]}";
do
amfTopFile=$exp/$f1-$j/$subexp/top_data_node1.txt
topCpuOpFile=$exp/$f1-$j/$subexp/topCpuOp.csv
queueLenFile=$exp/$f1-$j/$subexp/queueLen.csv
rm -f $topCpuOpFile
rm -f $queueLenFile

echo "Working on $topCpuOpFile"
sjCount=$(cat $amfTopFile | grep systemd-journal | wc -l)
echo "UTC-Time, Time-Diff, CPU-Usage" >> $topCpuOpFile
timestamps=( $(cat $amfTopFile | grep 2021- | grep -o '\-\-.*' | cut -c 3-) )
if (( $sjCount < 5 )); then
timestamps=("${timestamps[@]:1}")
fi
cpusage=( $(cat $amfTopFile | grep open5gs-amfd | awk '{print $9}') )
basecpu="0.0"
k=0
for i in "${!cpusage[@]}";
do
if (( $(echo "${cpusage[$i]} > $basecpu" |bc -l) )); then
mdtTs=${timestamps[$i]}
if [[ $k == 0 ]]; then
firstTs=$(TZ=UTC date -d "$mdtTs MDT - 0.2 second" +'%T.%3N')
firstEpochTs=$(date -d "$firstTs" +"%s.%3N")
echo "$firstTs, 0, $basecpu" >> $topCpuOpFile
fi
utcTs=$(TZ=UTC date -d "$mdtTs MDT" +'%T.%3N')
epochTs=$(date -d "$utcTs" +"%s.%3N")
timediff=$(echo -e "$epochTs-$firstEpochTs" | bc)
timediff=$(echo -e "$timediff*1000" | bc | rev | cut -c 5- | rev)
echo "$utcTs, $timediff, ${cpusage[$i]}" >> $topCpuOpFile
k=$k+1
if (( $(echo "${cpusage[$i]} > $basecpu" |bc -l) )); then
mdtTs=${timestamps[$i]}
if [[ $k == 0 ]]; then
firstTs=$(TZ=$commonTZ date -d "$mdtTs MDT - 0.2 second" +'%T.%3N')
firstEpochTs=$(date -d "$firstTs" +"%s.%3N")
echo "$firstTs, 0, $basecpu" >> $topCpuOpFile
fi
done
utcTs=$(TZ=UTC date -d "$mdtTs MDT + 0.2 second" +'%T.%3N')
utcTs=$(TZ=$commonTZ date -d "$mdtTs MDT" +'%T.%3N')
epochTs=$(date -d "$utcTs" +"%s.%3N")
timediff=$(echo -e "$epochTs-$firstEpochTs" | bc)
timediff=$(echo -e "$timediff*1000" | bc | rev | cut -c 5- | rev)
echo "$utcTs, $timediff, ${cpusage[$i]}" >> $topCpuOpFile
k=$k+1
fi
done
utcTs=$(TZ=$commonTZ date -d "$mdtTs MDT + 0.2 second" +'%T.%3N')
epochTs=$(date -d "$utcTs" +"%s.%3N")
timediff=$(echo -e "$epochTs-$firstEpochTs" | bc)
timediff=$(echo -e "$timediff*1000" | bc | rev | cut -c 5- | rev)
echo "$utcTs, $timediff, $basecpu" >> $topCpuOpFile

echo "Working on $queueLenFile"
echo "UTC-Time, Time-Diff, Queue-Length" >> $queueLenFile
mints=$(date -d "$(cat $topCpuOpFile | sed -n 2p | awk '{print $1}' | rev | cut -c 2- | rev)" +"%s.%3N")
maxts=$(date -d "$(cat $topCpuOpFile | tail -n1 | awk '{print $1}' | rev | cut -c 2- | rev)" +"%s.%3N")
#utcTs=( $(cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $2}' | sed -r "s/\x1B\[([0-9]{1,3}(;[0-9]{1,2})?)?[mGK]//g" | rev | cut -c 2- | rev) )
#queuelens=( $(cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $9}') )
sed -i '/Open5GS daemon v2/d' $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt
cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $1,$2}' | sed -r "s/\x1B\[([0-9]{1,3}(;[0-9]{1,2})?)?[mGK]//g" | rev | cut -c 2- | rev > /tmp/utcTs.txt
cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $9}' > /tmp/queuelens.txt
i=0
while IFS="" read -r line || [ -n "$line" ]
do
lineNum=$(( ++i ))
utcTs=$(TZ=$commonTZ date -d "$line MDT" +'%T.%3N')
opfmt=$(echo $utcTs | cut -c 1-)
epochTs=$(date -d "$utcTs" +"%s.%3N")
timediff=$(echo -e "$epochTs-$firstEpochTs" | bc)
timediff=$(echo -e "$timediff*1000" | bc | rev | cut -c 5- | rev)
echo "$utcTs, $timediff, $basecpu" >> $topCpuOpFile

echo "Working on $queueLenFile"
echo "UTC-Time, Time-Diff, Queue-Length" >> $queueLenFile
mints=$(date -d "$(cat $topCpuOpFile | sed -n 2p | awk '{print $1}' | rev | cut -c 2- | rev)" +"%s.%3N")
maxts=$(date -d "$(cat $topCpuOpFile | tail -n1 | awk '{print $1}' | rev | cut -c 2- | rev)" +"%s.%3N")
#utcTs=( $(cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $2}' | sed -r "s/\x1B\[([0-9]{1,3}(;[0-9]{1,2})?)?[mGK]//g" | rev | cut -c 2- | rev) )
#queuelens=( $(cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $9}') )
cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $2}' | sed -r "s/\x1B\[([0-9]{1,3}(;[0-9]{1,2})?)?[mGK]//g" | rev | cut -c 2- | rev > /tmp/utcTs.txt
cat $exp/$f1-$j/$subexp/open5gs-amf-deployment-*_logs.txt | grep " ogs_queue_size is" | grep "PCS " | awk '{print $9}' > /tmp/queuelens.txt
i=0
while IFS="" read -r line || [ -n "$line" ]
do
lineNum=$(( ++i ))
epochTs=$(date -d "$line" +"%s.%3N")
if (( $(echo "$epochTs > $mints" |bc -l) )); then
if (( $(echo "$epochTs < $maxts" |bc -l) )); then
timediff=$(echo -e "$epochTs-$mints" | bc)
timediff=$(echo -e "$timediff*1000" | bc | rev | cut -c 5- | rev)
qln=$(cat /tmp/queuelens.txt | sed -n ${lineNum}p)
echo "$line, $timediff, $qln" >> $queueLenFile
fi
if (( $(echo "$epochTs > $mints" |bc -l) )); then
if (( $(echo "$epochTs < $maxts" |bc -l) )); then
timediff=$(echo -e "$epochTs-$mints" | bc)
timediff=$(echo -e "$timediff*1000" | bc | rev | cut -c 5- | rev)
qln=$(cat /tmp/queuelens.txt | sed -n ${lineNum}p)
echo "$opfmt, $timediff, $qln" >> $queueLenFile
fi
done < /tmp/utcTs.txt
rm -f /tmp/utcTs.txt
rm -f /tmp/queuelens.txt
echo "Completed processing files from $exp/$f1-$j/$subexp/"
echo " "
done
fi
done < /tmp/utcTs.txt
rm -f /tmp/utcTs.txt
rm -f /tmp/queuelens.txt
echo "Completed processing files from $exp/$f1-$j/$subexp/"
echo " "
done
done
Loading

0 comments on commit 162fdbf

Please sign in to comment.