blob: 031adc2eacf592992ea0bd9ce7dc6ffa2bb32642 (
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
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
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
|
# make sure we can collect web log data
template: last_collected_secs
on: web_log.response_codes
families: *
calc: $now - $last_collected_t
units: seconds ago
every: 10s
warn: $this > (($status >= $WARNING) ? ($update_every) : ( 5 * $update_every))
crit: $this > (($status == $CRITICAL) ? ($update_every) : (60 * $update_every))
delay: down 5m multiplier 1.5 max 1h
info: number of seconds since the last successful data collection
to: webmaster
# -----------------------------------------------------------------------------
# high level response code alarms
# the following alarms trigger only when there are enough data.
# we assume there are enough data when:
#
# $1m_requests > 120
#
# i.e. when there are at least 120 requests during the last minute
template: 1m_requests
on: web_log.response_statuses
families: *
lookup: sum -1m unaligned
calc: ($this == 0)?(1):($this)
units: requests
every: 10s
info: the sum of all HTTP requests over the last minute
template: 1m_successful
on: web_log.response_statuses
families: *
lookup: sum -1m unaligned of successful_requests
calc: $this * 100 / $1m_requests
units: %
every: 10s
warn: ($1m_requests > 120) ? ($this < (($status >= $WARNING ) ? ( 95 ) : ( 85 )) ) : ( 0 )
crit: ($1m_requests > 120) ? ($this < (($status == $CRITICAL) ? ( 85 ) : ( 75 )) ) : ( 0 )
delay: up 2m down 15m multiplier 1.5 max 1h
info: the ratio of successful HTTP responses (1xx, 2xx, 304) over the last minute
to: webmaster
template: 1m_redirects
on: web_log.response_statuses
families: *
lookup: sum -1m unaligned of redirects
calc: $this * 100 / $1m_requests
units: %
every: 10s
warn: ($1m_requests > 120) ? ($this > (($status >= $WARNING ) ? ( 1 ) : ( 20 )) ) : ( 0 )
crit: ($1m_requests > 120) ? ($this > (($status == $CRITICAL) ? ( 20 ) : ( 30 )) ) : ( 0 )
delay: up 2m down 15m multiplier 1.5 max 1h
info: the ratio of HTTP redirects (3xx except 304) over the last minute
to: webmaster
template: 1m_bad_requests
on: web_log.response_statuses
families: *
lookup: sum -1m unaligned of bad_requests
calc: $this * 100 / $1m_requests
units: %
every: 10s
warn: ($1m_requests > 120) ? ($this > (($status >= $WARNING) ? ( 10 ) : ( 30 )) ) : ( 0 )
crit: ($1m_requests > 120) ? ($this > (($status == $CRITICAL) ? ( 30 ) : ( 50 )) ) : ( 0 )
delay: up 2m down 15m multiplier 1.5 max 1h
info: the ratio of HTTP bad requests (4xx) over the last minute
to: webmaster
template: 1m_internal_errors
on: web_log.response_statuses
families: *
lookup: sum -1m unaligned of server_errors
calc: $this * 100 / $1m_requests
units: %
every: 10s
warn: ($1m_requests > 120) ? ($this > (($status >= $WARNING) ? ( 1 ) : ( 2 )) ) : ( 0 )
crit: ($1m_requests > 120) ? ($this > (($status == $CRITICAL) ? ( 2 ) : ( 5 )) ) : ( 0 )
delay: up 2m down 15m multiplier 1.5 max 1h
info: the ratio of HTTP internal server errors (5xx), over the last minute
to: webmaster
# unmatched lines
# the following alarms trigger only when there are enough data.
# we assume there are enough data when:
#
# $1m_total_requests > 120
#
# i.e. when there are at least 120 requests during the last minute
template: 1m_total_requests
on: web_log.response_codes
families: *
lookup: sum -1m unaligned
calc: ($this == 0)?(1):($this)
units: requests
every: 10s
info: the sum of all HTTP requests over the last minute
template: 1m_unmatched
on: web_log.response_codes
families: *
lookup: sum -1m unaligned of unmatched
calc: $this * 100 / $1m_total_requests
units: %
every: 10s
warn: ($1m_total_requests > 120) ? ($this > 1) : ( 0 )
crit: ($1m_total_requests > 120) ? ($this > 5) : ( 0 )
delay: up 1m down 5m multiplier 1.5 max 1h
info: the ratio of unmatched lines, over the last minute
to: webmaster
# -----------------------------------------------------------------------------
# web slow
# the following alarms trigger only when there are enough data.
# we assume there are enough data when:
#
# $1m_requests > 120
#
# i.e. when there are at least 120 requests during the last minute
template: 10m_response_time
on: web_log.response_time
families: *
lookup: average -10m unaligned of avg
units: ms
every: 30s
info: the average time to respond to HTTP requests, over the last 10 minutes
template: web_slow
on: web_log.response_time
families: *
lookup: average -1m unaligned of avg
units: ms
every: 10s
green: 500
red: 1000
warn: ($1m_requests > 120) ? ($this > $green && $this > ($10m_response_time * 2) ) : ( 0 )
crit: ($1m_requests > 120) ? ($this > $red && $this > ($10m_response_time * 4) ) : ( 0 )
delay: down 15m multiplier 1.5 max 1h
info: the average time to respond to HTTP requests, over the last 1 minute
options: no-clear-notification
to: webmaster
# -----------------------------------------------------------------------------
# web too many or too few requests
# the following alarms trigger only when there are enough data.
# we assume there are enough data when:
#
# $5m_successful_old > 120
#
# i.e. when there were at least 120 requests during the 5 minutes starting
# at -10m and ending at -5m
template: 5m_successful_old
on: web_log.response_statuses
families: *
lookup: average -5m at -5m unaligned of successful_requests
units: requests/s
every: 30s
info: average rate of successful HTTP requests over the last 5 minutes
template: 5m_successful
on: web_log.response_statuses
families: *
lookup: average -5m unaligned of successful_requests
units: requests/s
every: 30s
info: average successful HTTP requests over the last 5 minutes
template: 5m_requests_ratio
on: web_log.response_codes
families: *
calc: ($5m_successful_old > 0)?($5m_successful * 100 / $5m_successful_old):(100)
units: %
every: 30s
warn: ($5m_successful_old > 120) ? ($this > 200 OR $this < 50) : (0)
crit: ($5m_successful_old > 120) ? ($this > 400 OR $this < 25) : (0)
delay: down 15m multiplier 1.5 max 1h
options: no-clear-notification
info: the percentage of successful web requests over the last 5 minutes, \
compared with the previous 5 minutes \
(clear notification for this alarm will not be sent)
to: webmaster
|