Revision 636532383338 () - Diff

Link to this snippet: https://friendpaste.com/378KlzPrDEAZL5An9ro9gh
Embed:
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
#!/usr/bin/env python
# -*- coding: utf-8 -*-

# /* vim: set filetype=python : */

"""Wildcard-plugin to monitor http response time.

To monitor a website, link response_time_<server address|fqdn> to this file.

E.g.

ln -s /usr/share/node/node/plugins-auto/response_time_http_ \
/etc/munin/node.d/response_time_http_192.168.0.10

... will monitor http response times to http://192.168.0.10/

If you wish to monitor the http response time to a particular page, use the
/etc/munin/plugin-conf.d/munin-node CONFIGuration file and add the following
section:

[response_time_http*]
env.url keepalived.php

You may add as many urls as you wish to, separated by colons:

[response_time_http_192.168.0.10]
env.url index.html:keepalived.php:testslowpage.html

"""

import sys
import os
from urllib2 import URLError
from timeit import Timer


USAGE = """\
To use this plugin, you must create a symbolic link to it,
with the ip address or fqdn of the web server to monitor.

E.g.

ln -s /usr/share/node/node/plugins-auto/response_time_http_ \
/etc/munin/node.d/response_time_http_192.168.0.10"""

CONFIG = """\
graph_title HTTP GET response time for %s
graph_vlabel seconds
ping_http.label response time
graph_info The response time for a GET to complete on the given server.
response_time_http.info Response time for a GET request to complete."""


def main(argv=None):
"""Main program.

If called with the "config" parameter, output munin configuration for this
graph.

"""

if argv is None:
argv = sys.argv

address = os.path.basename(argv[0]).replace('response_time_http_', '')

if not address:
print(USAGE)
return 1

if 'config' in sys.argv:
print(CONFIG % address)
else:
runs = 10
if 'runs' in os.environ:
runs = os.environ['runs']
runs = int(runs)

timeout = 5
if 'timeout' in os.environ:
timeout = os.environ['timeout']

try:
timer = Timer('urlopen("http://%s", None, %s)' % (address, timeout),
'from urllib2 import urlopen')
res = timer.timeit(runs)
print("response_time.value %s" % (res / runs))
except URLError:
print("response_time.value U")
return 0


if __name__ == '__main__':
sys.exit(main())