This repository has been archived by the owner on Aug 16, 2021. It is now read-only.
forked from kmova/zfs-utilities
-
Notifications
You must be signed in to change notification settings - Fork 3
/
check_vsm_throttling.sh
104 lines (90 loc) · 3.5 KB
/
check_vsm_throttling.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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#!/bin/sh
# Display the throttling counters on the volumes in a given vsm
# Usage: sh check_vsm_throttling.sh <jid|ip address> [duration]
if [ $# -lt 1 ] ; then
echo "Usage sh check_vsm_throttling.sh <jid|ip address> [duration]"
exit 1
fi
#Use 10 seconds as interval between the stats capture.
duration=10
if [ $# -gt 1 ] ; then
duration=$2
fi
#Get the jid, if an IP address is provided
jid=$1
ipregexp="\b(.*)\.(.*)\.(.*)\.(.*)\b"
rv=`echo $jid | egrep $ipregexp`
if [ $? -eq 0 ] ; then
echo "$jid is an ip address"
jid=`jls | grep $jid | awk '{print $1}'`
if [ -z $jid ] ; then
echo "Unable to find an VSM corresponding to IP Address $1"
exit
fi
fi
#Validate the jid is valid on this node
rv=`jexec $jid date`
if [ $? -ne 0 ] ; then
echo "Unable to find the VSM corresponding to $1"
exit
fi
#Create a temporary directory to store the collected stats
day=`date | tr -s " " | cut -f 2 -d " "`
dt=`date | tr -s " " | cut -f 3 -d " "`
ts=`date +%s`
sep="_"
CWD=`pwd`
BACKUP_DIR="RENG_$day$dt$sep$ts"
mkdir -p "${CWD}/$BACKUP_DIR"
#Collect stats on only the volumes
volumes=`jexec $jid zfs list | grep -v "NAME\|tpool" | awk '{print $1}' | xargs`
volregexp="\b(.*)\/(.*)\/(.*)\b"
echo "Name type Reads Writes Staggered" >> "${CWD}/$BACKUP_DIR/reng.stats"
for vol in $volumes
do
isvol=`echo $vol | egrep $volregexp`
if [ $? -eq 0 ] ; then
volname=`echo $vol | awk -F '/' '{print $3}'`
echo "Gathering stats for $volname"
reng stats access dataset $vol qos > "${CWD}/$BACKUP_DIR/prev.reng.stats.$volname"
pr=`grep "Reads" "${CWD}/$BACKUP_DIR/prev.reng.stats.$volname" | grep -v "Meta\|Disk" | awk '{print $2}'`
pw=`grep "Writes" "${CWD}/$BACKUP_DIR/prev.reng.stats.$volname" | grep -v "Meta\|Disk" | awk '{print $2}'`
ps=`grep "IO staggered" "${CWD}/$BACKUP_DIR/prev.reng.stats.$volname" | awk '{print $3}'`
echo "$volname prev $pr $pw $ps" >> "${CWD}/$BACKUP_DIR/reng.stats"
fi
done
echo "Waiting for $duration..."
sleep $duration
for vol in $volumes
do
isvol=`echo $vol | egrep $volregexp`
if [ $? -eq 0 ] ; then
echo "Gathering stats for $volname"
volname=`echo $vol | awk -F '/' '{print $3}'`
reng stats access dataset $vol qos > "${CWD}/$BACKUP_DIR/curr.reng.stats.$volname"
cr=`grep "Reads" "${CWD}/$BACKUP_DIR/curr.reng.stats.$volname" | grep -v "Meta\|Disk" | awk '{print $2}'`
cw=`grep "Writes" "${CWD}/$BACKUP_DIR/curr.reng.stats.$volname" | grep -v "Meta\|Disk" | awk '{print $2}'`
cs=`grep "IO staggered" "${CWD}/$BACKUP_DIR/curr.reng.stats.$volname" | awk '{print $3}'`
echo "$volname curr $cr $cw $cs" >> "${CWD}/$BACKUP_DIR/reng.stats"
fi
done
#Check for the difference between the current and previous values
echo "Name Reads Writes Staggered"
for vol in $volumes
do
isvol=`echo $vol | egrep $volregexp`
if [ $? -eq 0 ] ; then
volname=`echo $vol | awk -F '/' '{print $3}'`
pr=`grep "$volname prev" ${CWD}/$BACKUP_DIR/reng.stats | awk '{print $3}'`
pw=`grep "$volname prev" ${CWD}/$BACKUP_DIR/reng.stats | awk '{print $4}'`
ps=`grep "$volname prev" ${CWD}/$BACKUP_DIR/reng.stats | awk '{print $5}'`
cr=`grep "$volname curr" ${CWD}/$BACKUP_DIR/reng.stats | awk '{print $3}'`
cw=`grep "$volname curr" ${CWD}/$BACKUP_DIR/reng.stats | awk '{print $4}'`
cs=`grep "$volname curr" ${CWD}/$BACKUP_DIR/reng.stats | awk '{print $5}'`
tr=`echo $cr - $pr | bc`
tw=`echo $cw - $pw | bc`
ts=`echo $cs - $ps | bc`
echo "$volname diff $tr $tw $ts" >> "${CWD}/$BACKUP_DIR/reng.stats"
echo "$volname $tr $tw $ts"
fi
done