Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/freifunkbremen/yanic
Yet another node info collector - for respondd to be used with meshviewer to Grafana (with influxdb or graphite)
https://github.com/freifunkbremen/yanic
freifunk gluon grafana graphite influxdb meshviewer
Last synced: 4 days ago
JSON representation
Yet another node info collector - for respondd to be used with meshviewer to Grafana (with influxdb or graphite)
- Host: GitHub
- URL: https://github.com/freifunkbremen/yanic
- Owner: FreifunkBremen
- License: agpl-3.0
- Created: 2016-02-19T08:13:47.000Z (almost 9 years ago)
- Default Branch: main
- Last Pushed: 2024-07-19T22:45:20.000Z (6 months ago)
- Last Synced: 2025-01-17T07:04:41.238Z (4 days ago)
- Topics: freifunk, gluon, grafana, graphite, influxdb, meshviewer
- Language: Go
- Homepage: https://freifunkbremen.github.io/yanic/
- Size: 1.12 MB
- Stars: 20
- Watchers: 10
- Forks: 41
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Yanic
```
__ __ _
\ \ / /_ _ _ __ (_) ___
\ V / _` | '_ \| |/ __|
| | (_| | | | | | (__
|_|\__,_|_| |_|_|\___|
Yet another node info collector
```[![Test, Lint](https://github.com/FreifunkBremen/yanic/actions/workflows/go.yml/badge.svg)](https://github.com/FreifunkBremen/yanic/actions/workflows/go.yml)
[![codecov](https://codecov.io/gh/FreifunkBremen/yanic/branch/main/graph/badge.svg)](https://codecov.io/gh/FreifunkBremen/yanic)
[![Go Report Card](https://goreportcard.com/badge/github.com/FreifunkBremen/yanic)](https://goreportcard.com/report/github.com/FreifunkBremen/yanic)`yanic` is a respondd client that fetches, stores and publishes information about a Freifunk network. The goals:
* Generating JSON for [Meshviewer](https://github.com/ffrgb/meshviewer)
* Storing statistics in [InfluxDB](https://influxdata.com/) or [Graphite](https://graphiteapp.org/) to be analyzed by [Grafana](http://grafana.org/)
* Provide a little webserver for a standalone installation with a meshviewer## How it works
In the first step Yanic sends a multicast message to the group `ff05::2:1001` and port `1001`.
Recently seen nodes that does not reply are requested via a unicast message.## Documentation
Take a look at the [git](https://github.com/FreifunkBremen/yanic/blob/main/SUMMARY.md) or [website](https://freifunkbremen.github.io/yanic/)# Installation
Take a look into the Documentation (see above) or for Quick Overview in [INSTALL.md](INSTALL.md).If you like Docker you may want to take a look [here](https://github.com/christf/docker-yanic).
## Configuration
Read comments in [config_example.toml](config_example.toml) for more information.## Running
Yanic provides several commands:### Usage
Run Yanic without any arguments to get the usage information:
```
Usage:
yanic [command]Available Commands:
help Help about any command
import Imports global statistics from the given RRD files, requires InfluxDB
query Sends a query on the interface to the destination and waits for a response
serve Runs the yanic serverFlags:
-h, --help help for yanic
--loglevel uint32 Show log message starting at level (default 40)
--timestamps Enables timestamps for log outputUse "yanic [command] --help" for more information about a command.
```#### Serve
Runs the yanic server
```
Usage:
yanic serve [flags]Examples:
yanic serve --config /etc/yanic.tomlFlags:
-c, --config string Path to configuration file (default "config.toml")
-h, --help help for serveGlobal Flags:
--loglevel uint32 Show log message starting at level (default 40)
--timestamps Enables timestamps for log output
```#### Query
Sends a query on the interface to the destination and waits for a response
```
Usage:
yanic query [flags]Examples:
yanic query "eth0,wlan0" "fe80::eade:27ff:dead:beef"Flags:
-h, --help help for query
--ip string ip address which is used for sending (optional - without definition used the link-local address)
--port int define a port to listen (if not set or set to 0 the kernel will use a random free port at its own)
--wait int Seconds to wait for a response (default 1)Global Flags:
--loglevel uint32 Show log message starting at level (default 40)
--timestamps Enables timestamps for log output
```#### Import
Imports global statistics from the given RRD files (ffmap-backend).
```
Usage:
yanic import [flags]Examples:
yanic import --config /etc/yanic.toml olddata.rrd global globalFlags:
-c, --config string Path to configuration file (default "config.toml")
-h, --help help for importGlobal Flags:
--loglevel uint32 Show log message starting at level (default 40)
--timestamps Enables timestamps for log output
```## Communities using Yanic
* **Freifunk Aachen** uses InfluxDB, [Grafana](https://grafana.ffac.rocks), and [Meshviewer-FFM](https://map.aachen.freifunk.net).
* **Freifunk Bremen** uses InfluxDB, [Grafana](https://grafana.bremen.freifunk.net), and [Meshviewer](https://map.bremen.freifunk.net) with a patch to show state-version of `nodes.json`.
* **Freifunk Nord** uses [meshviewer](https://github.com/ffrgb/meshviewer) (commit 587740a) as frontend: https://mesh.freifunknord.de/
* **Freifunk Hannover** uses [Grafana](https://stats.ffh.zone), InfluxDB, and [Meshviewer](https://hannover.freifunk.net/karte/).
* **Freifunk Rhein-Sieg e.V.** uses InfluxDB, [Grafana](https://grafana.freifunk-rhein-sieg.net/), [Meshviewer](https://map.freifunk-rhein-sieg.net/) - see [Github](https://github.com/Freifunk-Rhein-Sieg/Ansible-FFlo)
* **Freifunk Ingolstadt** uses InfluxDB, [Grafana](https://grafana.freifunk-ingolstadt.de/), [Meshviewer](https://map.freifunk-ingolstadt.de/) - see https://git.bingo-ev.de/freifunk/mapserver-dockerDo you know someone else using Yanic? Create a [pull request](https://github.com/FreifunkBremen/yanic/issues/new?template=community.md&title=Mention+community+$name)!
## Related projects
Collecting data from respondd:
* [HopGlass Server](https://github.com/plumpudding/hopglass-server) written in Node.jsRespondd for servers:
* [mesh-announce](https://github.com/ffnord/mesh-announce) from ffnord
* [respondd](https://github.com/Sunz3r/ext-respondd) from Sunz3r## License
This software is licensed under the terms of the [AGPL v3 License](LICENSE).