aboutsummaryrefslogtreecommitdiffstats
path: root/coin/provisioning/common/shared/telegraf/telegraf-ioping.sh
blob: 528047ceba5a5f888595ccb66deb123221c97551 (plain)
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
#!/bin/sh
#Copyright (C) 2023 The Qt Company Ltd
#SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only

# Measure I/O latency once, return data in InfluxDB format
#
# Run one ioping command for read, and one for write.
# Each one sends 3 requests and reports the minimum time, in nanoseconds.
# (Because of limitations of ioping, we can't just send one request and get
#  the number back in the batch format. Additionally, the number seems to be
#  fluctuating quite a bit so taking the smallest number out of 3 requests is
#  stabilising it a bit.)


set -e

[ -z "$1" ] && echo "$0 takes a path as a first argument" && exit 1

# Try to run in high priority to avoid slow-downs because of
# factors other than I/O.
renice  -n -10 -p $$  >/dev/null 2>&1 ||  true


rlatency="$(ioping -B -k -c 3 -i 0.1     "$1" | cut -d " " -f 5)"
wlatency="$(ioping -B -k -c 3 -i 0.1 -W  "$1" | cut -d " " -f 5)"

printf "ioping,path=$1 read_latency_ns=%u,write_latency_ns=%u\n"  \
       "$rlatency" "$wlatency"