-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun.sh
80 lines (64 loc) · 2.69 KB
/
run.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/bin/bash
#SBATCH --nodes=5
#SBATCH --ntasks=5
#SBATCH --cpus-per-task=8
#SBATCH --output="result.log"
#SBATCH --mem=15G
#SBATCH -p short # This is the default partition, you can use any of the following; intel, batch, highmem, gpu
#SBATCH --constraint="amd"
nodes=($( scontrol show hostnames $SLURM_NODELIST ))
nnodes=${#nodes[@]}
last=$(( $nnodes - 1 ))
DORY_HOME="/rhome/fhous001/farzin/FastChain/dory"
RESULT_LOC="/rhome/fhous001/farzin/FastChain/dory/wellcoordination/workload/"
RESULTS_DIR_NAME="AE_results"
NUM_NODES=$1
NUM_OPS=$2
WRITE_PERC=$3
MODE=$4 # mu, band, band-crdt, band-crdt-failure band-failure
REP=$5 # number of reps
USECASE=$6 # name of the usecase: project, courseware, movie, gset, counter
THROUGHPUT=$7 # 1 to calculate throughput, 0 to calculate response times
FAILURE=$8 # 0 for no failure, 1 for follower and 2 for leader failure
EXECUTION="response"
if [ "$THROUGHPUT" -eq 1 ]; then
EXECUTION="throughput"
fi
CRASH="no"
if [ "$FAILURE" -eq 1 ]; then
CRASH="leader"
fi
if [ "$FAILURE" -eq 2 ]; then
CRASH="follower"
fi
if [ "$#" -ne 6 ]; then
echo "Illegal number of parameters"
fi
BENCH_DIRECTORY=$RESULT_LOC$NUM_NODES-$NUM_OPS-$WRITE_PERC/$USECASE;
echo $BENCH_DIRECTORY;
if [ ! -d "$BENCH_DIRECTORY" ]; then
mkdir -p $BENCH_DIRECTORY;
/rhome/fhous001/farzin/FastChain/dory/wellcoordination/benchmark/$USECASE-benchmark.out $NUM_NODES $NUM_OPS $WRITE_PERC;
echo "benchmark generated";
fi
hostlist=""
for i in $( seq 0 $last ); do
hostlist+="${nodes[$i]} "
done
echo $hostlist
mkdir -p $BENCH_DIRECTORY/$RESULTS_DIR_NAME;
#for n in $( seq 3 6 ); do
for r in $( seq 1 $REP ); do
ssh ${nodes[0]}.ib.hpcc.ucr.edu 'memcached -vv -p 9999'&
sleep 2;
for i in $( seq 1 $NUM_NODES ); do
printf "ssh ${nodes[$i]}.ib.hpcc.ucr.edu 'cd ${DORY_HOME}; export DORY_REGISTRY_IP=${nodes[0]}:9999; ./wellcoordination/build/bin/$MODE $i $NUM_NODES $NUM_OPS $WRITE_PERC $USECASE $THROUGHPUT $FAILURE > $RESULT_LOC$NUM_NODES-$NUM_OPS-$WRITE_PERC/$USECASE/$RESULTS_DIR_NAME/$MODE-$i-$r-$EXECUTION-$CRASH.log'\n";
ssh ${nodes[$i]}.ib.hpcc.ucr.edu "cd ${DORY_HOME}; export DORY_REGISTRY_IP=${nodes[0]}:9999; ./wellcoordination/build/bin/$MODE $i $NUM_NODES $NUM_OPS $WRITE_PERC $USECASE $THROUGHPUT $FAILURE > $RESULT_LOC$NUM_NODES-$NUM_OPS-$WRITE_PERC/$USECASE/$RESULTS_DIR_NAME/$MODE-$i-$r-$EXECUTION-$CRASH.log&";
done
sleep 100;
ssh ${nodes[0]}.ib.hpcc.ucr.edu "bash -s" <./kill-memcached.sh
sleep 2;
done
ssh ${nodes[0]}.ib.hpcc.ucr.edu "bash -s" <./kill-memcached.sh
# done
sleep 300