]> arthur.barton.de Git - netdata.git/blob - python.d/squid.chart.py
fix squid autodetection
[netdata.git] / python.d / squid.chart.py
1 # -*- coding: utf-8 -*-
2 # Description: squid netdata python.d module
3 # Author: Pawel Krupa (paulfantom)
4
5 from base import SocketService
6
7 # default module values (can be overridden per job in `config`)
8 # update_every = 2
9 priority = 60000
10 retries = 5
11
12 # charts order (can be overridden if you want less charts, or different order)
13 ORDER = ['clients_net', 'clients_requests', 'servers_net', 'servers_requests']
14
15 CHARTS = {
16     'clients_net': {
17         'options': [None, "Squid Client Bandwidth", "kilobits/s", "clients", "squid.clients.net" "area"],
18         'lines': [
19             ["client_http_kbytes_in", "in", "incremental", 8, 1],
20             ["client_http_kbytes_out", "out", "incremental", -8, 1],
21             ["client_http_hit_kbytes_out", "hits", "incremental", -8, 1]
22         ]},
23     'clients_requests': {
24         'options': [None, "Squid Client Requests", "requests/s", "clients", "squid.clients.requests", 'line'],
25         'lines': [
26             ["client_http_requests", "requests"],
27             ["client_http_hits", "hits"],
28             ["client_http_errors", "errors", "incremental", -1, 1]
29         ]},
30     'servers_net': {
31         'options': [None, "Squid Server Bandwidth", "kilobits/s", "servers", "squid.servers.net" "area"],
32         'lines': [
33             ["server_all_kbytes_in", "in", "incremental", 8, 1],
34             ["server_all_kbytes_out", "out", "incremental", -8, 1]
35         ]},
36     'servers_requests': {
37         'options': [None, "Squid Server Requests", "requests/s", "servers", "squid.servers.requests", 'line'],
38         'lines': [
39             ["server_all_requests", "requests"],
40             ["server_all_errors", "errors", "incremental", -1, 1]
41         ]}
42 }
43
44
45 class Service(SocketService):
46     def __init__(self, configuration=None, name=None):
47         SocketService.__init__(self, configuration=configuration, name=name)
48         self.request = ""
49         self.host = "localhost"
50         self.port = 3128
51         self.order = ORDER
52         self.definitions = CHARTS
53
54     def _get_data(self):
55         """
56         Get data via http request
57         :return: dict
58         """
59         try:
60             raw = self._get_raw_data().split('\n')
61             if "200 OK" not in raw[0]:
62                 return None
63             data = {}
64             for row in raw:
65                 if row.startswith(("client", "server.all")):
66                     tmp = row.split("=")
67                     data[tmp[0].replace('.', '_').strip(' ')] = int(tmp[1])
68
69             if len(data) == 0:
70                 return None
71             return data
72         except (ValueError, AttributeError):
73             return None
74
75     def check(self):
76         """
77         Parse essential configuration, autodetect squid configuration (if needed), and check if data is available
78         :return: boolean
79         """
80         self._parse_config()
81         # format request
82         req = self.request.decode()
83         if not req.startswith("GET"):
84             req = "GET " + req
85         if not req.endswith(" HTTP/1.0\r\n\r\n"):
86             req += " HTTP/1.0\r\n\r\n"
87         self.request = req.encode()
88         #
89         # # autodetect squid
90         # if type(self.port) is tuple:
91         #     ports = self.port
92         #     for port in ports:
93         #         self.port = port
94         #         urls = ["cache_object://" + self.host + ":" + str(port) + "/counters",
95         #                 "/squid-internal-mgr/counters"]
96         #         for url in urls:
97         #             tmp = "GET " + url + " HTTP/1.0\r\n\r\n"
98         #             self.request = tmp.encode()
99         #             if self._get_data() is not None:
100         #                 return True
101         # else:
102         if True:
103             self.error("NEED: " + str(self._get_data()))
104             if self._get_data() is not None:
105                 return True
106             else:
107                 return False
108             
109                 
110                 
111                 
112             
113                 
114             
115