-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathlog_knownerrors.rb
executable file
·46 lines (38 loc) · 1.25 KB
/
log_knownerrors.rb
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
#!/usr/bin/ruby
##################
#
# This is all sorts of dirty, but we've all been in situations where
# some software spits errors into a logfile, and if we had looked for
# and caught such errors, we'd have avoided pain.
#
# This script was written by [email protected]. You can do whatever
# you want with it, but there is no warranty and you should feel
# free to send a thank you along with *tasty* whiskey.
#
##################
if (ARGV.length < 2 || ARGV[0] !~ /\w+/ || ARGV[1] !~ /\w+/)
puts "Searches for an error in the last 100 lines of a log file.
usage: #{$0} <file> <warning> <optional:number of lines to parse>
where <file> is the full path to the log file we're checking
and <warning> is the string we should alert on.
and the optional third field is number of lines of <file> to read. If empty, this is 100 lines."
exit 1
end
lines = ARGV[2]
if ( lines =~ /^\d+$/ )
lines = lines.to_i
elsif ( lines == '' || lines == nil )
lines = 100
else
puts "the optional third argument must be an integer!"
exit
end
file = ARGV[0]
warning = ARGV[1]
logentries = []
logentries=`/usr/bin/tail -#{lines} #{file} |grep -e "#{warning}"`
if (logentries.size > 0)
puts "status err bad entires for \"#{warning}\" in #{file}"
else
puts "status ok ok"
end