Skip to content

Commit

Permalink
Improve logging and error handling in benchmark script
Browse files Browse the repository at this point in the history
Signed-off-by: Daniel Carl Jones <[email protected]>
  • Loading branch information
dannycjones committed Sep 7, 2023
1 parent 4db11ad commit eae103e
Showing 1 changed file with 25 additions and 21 deletions.
46 changes: 25 additions & 21 deletions mountpoint-s3/scripts/fs_bench.sh
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#!/bin/bash
set -e

if ! command -v fio &> /dev/null; then
echo "fio must be installed to run this benchmark"
Expand Down Expand Up @@ -32,7 +33,7 @@ cd ${project_dir}
results_dir=results
runtime_seconds=30
startdelay_seconds=30
iteration=10
iterations=10

rm -rf ${results_dir}
mkdir -p ${results_dir}
Expand All @@ -45,43 +46,43 @@ run_fio_job() {
job_name=$(basename "${job_file}")
job_name="${job_name%.*}"

for i in $(seq 1 $iteration);
echo -n "Running job ${job_name} for ${iterations} iterations... "

for i in $(seq -w 1 $iterations);
do
echo -n "${i};"
fio --thread \
--output=${results_dir}/${job_name}_${i}.json \
--output=${results_dir}/${job_name}_iter${i}.json \
--output-format=json \
--directory=${mount_dir} \
--filename=${bench_file} \
--eta=never \
${job_file}
done
echo "done"

# combine the results and find an average value
jq -n 'reduce inputs.jobs[] as $job (null; .name = $job.jobname | .len += 1 | .value += (if ($job."job options".rw == "read")
then $job.read.bw / 1024
elif ($job."job options".rw == "randread") then $job.read.bw / 1024
elif ($job."job options".rw == "randwrite") then $job.write.bw / 1024
else $job.write.bw / 1024 end)) | {name: .name, value: (.value / .len), unit: "MiB/s"}' ${results_dir}/${job_name}_*.json | tee ${results_dir}/${job_name}_parsed.json

# delete the raw output files
for i in $(seq 1 $iteration);
do
rm ${results_dir}/${job_name}_${i}.json
done
else $job.write.bw / 1024 end)) | {name: .name, value: (.value / .len), unit: "MiB/s"}' ${results_dir}/${job_name}_iter*.json | tee ${results_dir}/${job_name}_parsed.json
}

read_bechmark () {
read_benchmark () {
jobs_dir=mountpoint-s3/scripts/fio/read

for job_file in "${jobs_dir}"/*.fio; do
mount_dir=$(mktemp -d /tmp/fio-XXXXXXXXXXXX)

echo "Running ${job_name}"

# mount file system
cargo run --release ${S3_BUCKET_NAME} ${mount_dir} \
set +e
cargo run --quiet --release -- \
${S3_BUCKET_NAME} ${mount_dir} \
--allow-delete \
--prefix=${S3_BUCKET_TEST_PREFIX}
mount_status=$?
set -e
if [ $mount_status -ne 0 ]; then
echo "Failed to mount file system"
exit 1
Expand Down Expand Up @@ -111,13 +112,16 @@ write_benchmark () {
for job_file in "${jobs_dir}"/*.fio; do
# mount file system
mount_dir=$(mktemp -d /tmp/fio-XXXXXXXXXXXX)
cargo run --release ${S3_BUCKET_NAME} ${mount_dir} \
--allow-delete \
--prefix=${S3_BUCKET_TEST_PREFIX}
set +e
cargo run --quiet --release -- \
${S3_BUCKET_NAME} ${mount_dir} \
--allow-delete \
--prefix=${S3_BUCKET_TEST_PREFIX}
mount_status=$?
set -e
if [ $mount_status -ne 0 ]; then
echo "Failed to mount file system"
exit 1
echo "Failed to mount file system"
exit 1
fi

# set bench file
Expand All @@ -134,8 +138,8 @@ write_benchmark () {
done
}

read_bechmark
read_benchmark
write_benchmark

# combine all bench results into one json file
jq -n '[inputs]' ${results_dir}/*.json | tee ${results_dir}/output.json
jq -n '[inputs]' ${results_dir}/*_parsed.json | tee ${results_dir}/output.json

0 comments on commit eae103e

Please sign in to comment.