-
-
Notifications
You must be signed in to change notification settings - Fork 134
/
Copy pathsyslog-errors-infrequent.sh
executable file
·60 lines (51 loc) · 2.11 KB
/
syslog-errors-infrequent.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
#!/bin/bash
#
# Send interesting parts of syslog from the last 3 hours. Simple logcheck.
#
# VERSION :1.0.1
# DATE :2021-03-18
# AUTHOR :Viktor Szépe <[email protected]>
# LICENSE :The MIT License (MIT)
# URL :https://github.com/szepeviktor/debian-server-tools
# BASH-VERSION :4.2+
# DOCS :https://www.youtube.com/watch?v=pYYtiIwtQxg
# DEPENDS :apt-get install logtail
# LOCATION :/usr/local/sbin/syslog-errors-infrequent.sh
# CRON.D :17 */3 * * * root /usr/local/sbin/syslog-errors-infrequent.sh
# TODO More words: https://github.com/raszi/colorize/blob/master/colorize#L21-L22
Filter_failures()
{
# -intERRupt,-bERRy, -WARNer, -fail2ban, -MISSy, -deFAULT
grep --extended-regexp --ignore-case "crit|[^f]err[os]|warn[^e]|fail[^2]\
|alert|unknown|unable|miss[^y]|except|disable|invalid|[^e]fault|cannot|denied\
|broken|exceed|too big|too many|unsafe|unsolicited|limit reach|unhandled|traps\
|\\bbad\\b|corrupt|but got status|oom-killer|false|unreach|[^c]oops|ignor[ei]\
|prohibit|timeout|blocked|unavailable|over quota|unconfigured"
}
LOG_EXCERPT="$(mktemp --suffix=.syslog)"
# Search recent log entries
/usr/sbin/logtail2 /var/log/syslog \
| cat --show-tabs --show-nonprinting \
| grep --fixed-strings --invert-match "$0" \
| Filter_failures \
> "${LOG_EXCERPT}"
printf '%d failures total.\n' "$(wc -l <"${LOG_EXCERPT}")"
while read -r PATTERN; do
COUNT="$(grep --extended-regexp --count "${PATTERN}" "${LOG_EXCERPT}")"
if [ "${COUNT}" == 0 ]; then
continue
fi
printf 'Ignored: %4d × #%s#\n' "${COUNT}" "${PATTERN}"
done </etc/syslog-errors-excludes.grep
grep --extended-regexp --invert-match --file=/etc/syslog-errors-excludes.grep "${LOG_EXCERPT}" \
| dd iflag=fullblock bs=1M count=5 2>/dev/null
rm "${LOG_EXCERPT}"
# Process boot log
if [ -s /var/log/boot ] && [ "$(wc -l </var/log/boot)" -gt 1 ]; then
# Skip "(Nothing has been logged yet.)"
/usr/sbin/logtail2 /var/log/boot \
| sed -e '1!b;/^(Nothing has been logged yet.*$/d' \
| cat --show-tabs --show-nonprinting \
| Filter_failures
fi
exit 0