This repository has been archived by the owner on Nov 22, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 67
/
check_smart.sh
166 lines (141 loc) · 5.03 KB
/
check_smart.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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
#!/bin/bash
# Check S.M.A.R.T. (check_smart.sh)
# by Dan Barrett
# http://yesdevnull.net
# v1.0 - 9 Aug 2013
# Initial release.
# Read S.M.A.R.T. data from the specified disk using smartmontools
# (http://sourceforge.net/apps/trac/smartmontools/wiki)
# Arguments:
# -d Drive BSD name (disk0/disk1 etc)
# -g Graph item(s)
# Example:
# ./check_smart.sh -d disk0 -g "badSectors tempCelcius"
# OR
# ./check_smart.sh -d disk1
# Performance Data
# * badSectors Number of bad sectors on disk
# * reallocSectors Number of re-allocated sectors on disk
# * powerOnHours Number of hours the disk has been powered on for
# * tempCelcius Temperature in celcius of the disk (internal)
# * retiredBlockCount Number of retired blocks
# * lifetimeWrites Number of lifetime writes (in GiB)
# * lifetimeReads Number of lifetime read (in GiB)
# Supports:
# * OS X 10.8.x
# * OS X 10.9
disk=""
graphs=""
graphString=""
badSectors=0
reallocSectors=0
# Get the flags!
while getopts "d:g:" opt
do
case $opt in
d ) disk=$OPTARG;;
g ) graphs=$OPTARG;;
esac
done
# enable SMART on the drive if it is not already
smartoncmd=`/opt/local/libexec/nagios/smartctl --smart=on --saveauto=on $disk`
resultString=`/opt/local/libexec/nagios/smartctl -H $disk`
if echo $graphs | grep -q -E "[A-Za-z ]+"
then
graphString="|"
fi
# Did user want badSectors graph?
if echo $graphs | grep -q "badSectors"
then
badSectors=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Reallocated_Sector_Ct' | grep -E -o "[0-9]+" | tail -1 `
graphString="$graphString badSectors=$badSectors;"
fi
# Did user want reallocSectors graph?
if echo $graphs | grep -q "reallocSectors"
then
reallocSectors=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Reallocated_Event_Count' | grep -E -o "[0-9]+" | tail -1`
graphString="$graphString reallocSectors=$reallocSectors;"
fi
# Did user want powerOnHours graph?
if echo $graphs | grep -q "powerOnHours"
then
powerOnHours=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Power_On_Hours' | grep -E -o "[0-9]+" | tail -1`
graphString="$graphString powerOnHours=$powerOnHours;"
fi
# Did user want tempCelcius graph?
if echo $graphs | grep -q "tempCelcius"
then
internalTemp=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Temperature_Celsius' | grep -E -o "[0-9]+[^0-9/\)]" | sed 's/ //g' | tail -1`
graphString="$graphString tempCelcius=$internalTemp;"
fi
# Did user want retiredBlockCount graph?
if echo $graphs | grep -q "retiredBlockCount"
then
retiredBlockCount=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Retired_Block_Count' | grep -E -o "[0-9]+" | tail -1`
graphString="$graphString retiredBlockCount=$retiredBlockCount;"
fi
# Did user want lifetimeWrites graph?
if echo $graphs | grep -q "lifetimeWrites"
then
lifetimeWrites=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Lifetime_Writes_GiB' | grep -E -o "[0-9]+" | tail -1`
graphString="$graphString lifetimeWrites=$lifetimeWrites;"
fi
# Did user want lifetimeReads graph?
if echo $graphs | grep -q "lifetimeReads"
then
lifetimeReads=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Lifetime_Reads_GiB' | grep -E -o "[0-9]+" | tail -1`
graphString="$graphString lifetimeReads=$lifetimeReads;"
fi
if echo $resultString | grep -q "PASSED"
then
printf "OK - All S.M.A.R.T. attributes passed $graphString\n"
exit 0
else
# Check to see if there's been many seek error rates
seekErrorRateRaw=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Seek_Error_Rate' | grep -E -o "[0-9]+" | tail -1`
if [ $seekErrorRateRaw -gt 50 ]
then
printf "CRITICAL - Drive is having constant read errors! $graphString\n"
exit 2
fi
if [ $seekErrorRateRaw -gt 25 ]
then
printf "WARNING - Drive has had multiple read errors! $graphString\n"
exit 1
fi
# Make sure the drive isn't hitting its maximum temperature!
tempRaw=`/opt/local/libexec/nagios/smartctl -a $disk | grep -C 0 'Temperature_Celsius' | grep -E -o "[0-9]+" | tail -1`
if [ $tempRaw -gt 65 ]
then
printf "CRITICAL - Drive is maxing out its maximum designed temperature! $graphString\n"
exit 2
fi
if [ $tempRaw -gt 60 ]
then
printf "WARNING - Drive is close to its maximum designed temperature! $graphString\n"
exit 1
fi
# Get the first line that is FAILING_NOW
failString=`echo $resultString | grep -C 0 'FAILING_NOW'`
# Now we make a human readable error message
if echo $failString | grep -q "Reallocated_Sector_Ct\|Reallocated_Event_Count"
then
printf "CRITICAL - Drive has bad sectors! $graphString\n"
exit 2
elif echo $failString | grep -q "Command_Timeout"
then
printf "CRITICAL - Drive is having constant timeout issues, check any power sources! $graphString\n"
exit 2
elif echo $failString | grep -q "Temperature_Celsius"
then
printf "CRITICAL - Drive is exposed to extreme temperatures! $graphString\n"
exit 2
elif echo $failString | grep -q "Seek_Error_Rate\|Raw_Read_Error_Rate"
then
printf "CRITICAL - Drive is having constant read errors! $graphString\n"
exit 2
else
printf "WARNING - Drive has failing S.M.A.R.T. attributes! $graphString\n"
exit 1
fi
fi