Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dsdatsme/ping-loss-monitor
https://github.com/dsdatsme/ping-loss-monitor
grafana hacktoberfest influxdb monitoring-scripts
Last synced: 22 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/dsdatsme/ping-loss-monitor
- Owner: DSdatsme
- License: mit
- Created: 2021-02-05T17:40:03.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2022-10-07T03:54:14.000Z (over 2 years ago)
- Last Synced: 2024-10-31T23:22:43.288Z (2 months ago)
- Topics: grafana, hacktoberfest, influxdb, monitoring-scripts
- Language: Python
- Homepage:
- Size: 9.77 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Packet Loss Monitor
This is a demo code to show how we can monitor internet packet loss on grafana dashboard on a laptop.
The goal of this repo is to add understanding how one can develop custom monitoring agents, collect metrics and later visualize it on dashboards.
## Tools used
- Flask for Grafana App
- SQLite for storing data
- Grafana for viewing graphs## Setup Components
### Setup SQLite Database
#### Create Database
Run the following command in your shell to create database.
```bash
sqlite3 monitor.db
```This creates a file in your current directory.
#### Create Table
Now you will be inside sqlite prompt, copy the following to create a table `packet_latency`
```sql
CREATE TABLE packet_latency (
epoc INT PRIMARY KEY NOT NULL,
min REAL NOT NULL,
avg REAL NOT NULL,
max REAL NOT NULL,
stddev REAL NOT NULL
);
```### Setup Agent
- This is a simple bash script. Update the `SQLITE_DATABASE_PATH` to the database file created above.
> Tip: use absolute path for `SQLITE_DATABASE_PATH` to avoid any dir not found issues.
- Also update ping binary path in variable `PING_BIN_PATH`. This is generally required if you are on Mac. You can find it by running the command `which ping`. Keep `PING_BIN_PATH=ping` if that works for you.
- Use crontab or add entry to `/etc/cron.d/root_cron. Add the following entry```bash
*/2 * * * * bash /PATH/TO/REPO/check_packetloss.sh
```This cron runs every 2 minute. Update it as per your need.
### Setup Flask App
This is the backend server that will query SQLite and server data to Grafana SimpleJson plugin.
Install the required dependencies
```bash
pip3 install Flask==1.1.2 db-sqlite3==3 0.0.1
```This should suffice, as everything else should be already part of python3.
Run the flask server
```bash
python3 app.py
```This should start a flask server, verify it by running following commands in different shell
```bash
curl localhost:5000
> OKcurl -XPOST localhost:5000/search
> ["min_latency","avg_latency","max_latency","stddev_latency"]
```where `localhost:5000` is your flask server endpoint.
### Setup Grafana
- Use the official docs to install grafana: [here](https://grafana.com/docs/grafana/latest/installation/)
- Install the Grafana plugin `SimpleJson`: [here](https://grafana.com/grafana/plugins/grafana-simple-json-datasource/installation)
- Make sure you restart the Grafana server after plugin is installed.
- Open grafana UI, mostly it runs on `localhost:3000`. The default login creds would be `admin admin`.
- To setup DataSource,
- go to `http://localhost:3000/datasources`
- Click `Add Datasource`
- Search for SimpleJson and select it
- `Name` it anything you like
- In the `URL` field, add the URL of flask server, i.e. `localhost:5000`
- Click `Save & Test`, There should be a green popup saying `Data source is working`.- Done, you can now create Grafana dashboards.
> You can also checkout `sample-dashboard.json` if you just want to avoid the hassel for creating a new dashboard manually.