mirror of
https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
synced 2025-11-01 11:18:03 +00:00
Create influx recording script
Signed-off-by: Matthew Stidham <stidmatt@protonmail.com>
This commit is contained in:
122
py-scripts/recordinflux.py
Executable file
122
py-scripts/recordinflux.py
Executable file
@@ -0,0 +1,122 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
"""recordinflux will record data from existing lanforge endpoints to record to an already existing influx database.
|
||||||
|
|
||||||
|
This data can then be streamed in Grafana or any other graphing program the user chooses while this script runs.
|
||||||
|
|
||||||
|
https://influxdb-python.readthedocs.io/en/latest/include-readme.html
|
||||||
|
|
||||||
|
|
||||||
|
Use './recordinflux.py --help' to see command line usage and options
|
||||||
|
Copyright 2021 Candela Technologies Inc
|
||||||
|
License: Free to distribute and modify. LANforge systems must be licensed.
|
||||||
|
"""
|
||||||
|
import sys
|
||||||
|
import os
|
||||||
|
|
||||||
|
if sys.version_info[0] != 3:
|
||||||
|
print("This script requires Python 3")
|
||||||
|
exit(1)
|
||||||
|
|
||||||
|
if 'py-json' not in sys.path:
|
||||||
|
sys.path.append(os.path.join(os.path.abspath('..'), 'py-json'))
|
||||||
|
|
||||||
|
import requests
|
||||||
|
import json
|
||||||
|
from influxdb import InfluxDBClient
|
||||||
|
import datetime
|
||||||
|
from LANforge.lfcli_base import LFCliBase
|
||||||
|
import argparse
|
||||||
|
import time
|
||||||
|
|
||||||
|
class graphdata(LFCliBase):
|
||||||
|
def __init__(self,
|
||||||
|
_host="localhost",
|
||||||
|
_port=8080,
|
||||||
|
_influx_user=None,
|
||||||
|
_influx_passwd=None,
|
||||||
|
_influx_db=None,
|
||||||
|
_longevity=None,
|
||||||
|
_monitor_interval=None,
|
||||||
|
_devices=None,
|
||||||
|
_debug_on=False,
|
||||||
|
_exit_on_fail=False
|
||||||
|
):
|
||||||
|
super().__init__(_host,
|
||||||
|
_port,
|
||||||
|
_debug=_debug_on,
|
||||||
|
_exit_on_fail=_exit_on_fail)
|
||||||
|
self.host=_host
|
||||||
|
self.port=_port
|
||||||
|
self.influx_user=_influx_user
|
||||||
|
self.influx_passwd=_influx_passwd
|
||||||
|
self.influx_db=_influx_db
|
||||||
|
self.longevity=_longevity
|
||||||
|
self.stations=_devices
|
||||||
|
self.monitor_interval=_monitor_interval
|
||||||
|
def getdata(self):
|
||||||
|
url='http://192.168.1.32:8080/port/1/1/'
|
||||||
|
client = InfluxDBClient(self.host,
|
||||||
|
8086,
|
||||||
|
self.influx_user,
|
||||||
|
self.influx_passwd,
|
||||||
|
self.influx_db)
|
||||||
|
end=datetime.datetime.now()+datetime.timedelta(0, self.longevity)
|
||||||
|
while datetime.datetime.now() < end:
|
||||||
|
stations=self.stations
|
||||||
|
for station in stations:
|
||||||
|
url1=url+station
|
||||||
|
response = json.loads(requests.get(url1).text)
|
||||||
|
for key in response['interface'].keys():
|
||||||
|
json_body = [
|
||||||
|
{
|
||||||
|
"measurement": station+' '+key,
|
||||||
|
"tags": {
|
||||||
|
"host": self.host,
|
||||||
|
"region": "us-west"
|
||||||
|
},
|
||||||
|
"time":str(datetime.datetime.utcnow().isoformat()),
|
||||||
|
"fields": {
|
||||||
|
"value":response['interface'][key]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
client.write_points(json_body)
|
||||||
|
time.sleep(self.monitor_interval)
|
||||||
|
|
||||||
|
def main():
|
||||||
|
parser = LFCliBase.create_bare_argparse(
|
||||||
|
prog='recordinflux.py',
|
||||||
|
formatter_class=argparse.RawTextHelpFormatter,
|
||||||
|
epilog='''
|
||||||
|
Record data to an Influx database in order to be able stream to Grafana or other graphing software''',
|
||||||
|
description='''
|
||||||
|
recordinflux.py:
|
||||||
|
----------------------------
|
||||||
|
Generic command example:
|
||||||
|
./recordinflux.py --influx_user lanforge \\
|
||||||
|
--influx_passwd password \\
|
||||||
|
--influx_db lanforge \\
|
||||||
|
--stations \\
|
||||||
|
--longevity 5h'''
|
||||||
|
)
|
||||||
|
parser.add_argument('--influx_user', help='Username for your Influx database', required=True)
|
||||||
|
parser.add_argument('--influx_passwd', help='Password for your Influx database', required=True)
|
||||||
|
parser.add_argument('--influx_db', help='Name of your Influx database', required=True)
|
||||||
|
parser.add_argument('--longevity', help='How long you want to gather data', default='4h')
|
||||||
|
parser.add_argument('--device', help='Device to monitor', action='append', required=True)
|
||||||
|
parser.add_argument('--monitor_interval', help='How frequently you want to append to your database', default='5s')
|
||||||
|
args = parser.parse_args()
|
||||||
|
monitor_interval=LFCliBase.parse_time(args.monitor_interval).total_seconds()
|
||||||
|
longevity=LFCliBase.parse_time(args.longevity).total_seconds()
|
||||||
|
grapher=graphdata(_host=args.mgr,
|
||||||
|
_port=args.mgr_port,
|
||||||
|
_influx_db=args.influx_db,
|
||||||
|
_influx_user=args.influx_user,
|
||||||
|
_influx_passwd=args.influx_passwd,
|
||||||
|
_longevity=longevity,
|
||||||
|
_devices=args.device,
|
||||||
|
_monitor_interval=monitor_interval)
|
||||||
|
grapher.getdata()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
Reference in New Issue
Block a user