Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/toni-moreno/snmpcollector
A full featured Generic SNMP data collector with Web Administration Interface for InfluxDB
https://github.com/toni-moreno/snmpcollector
cacti collector discovery golang influxdb metrics monitoring networking opennms performance performance-monitoring qos snmp solarwinds time-series
Last synced: 2 months ago
JSON representation
A full featured Generic SNMP data collector with Web Administration Interface for InfluxDB
- Host: GitHub
- URL: https://github.com/toni-moreno/snmpcollector
- Owner: toni-moreno
- License: mit
- Created: 2016-04-15T11:43:20.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-12-18T23:01:40.000Z (about 1 year ago)
- Last Synced: 2024-08-02T07:10:50.190Z (5 months ago)
- Topics: cacti, collector, discovery, golang, influxdb, metrics, monitoring, networking, opennms, performance, performance-monitoring, qos, snmp, solarwinds, time-series
- Language: Go
- Homepage:
- Size: 12 MB
- Stars: 284
- Watchers: 39
- Forks: 53
- Open Issues: 43
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-influxdb - snmpcollector - A full featured Generic SNMP data collector with Web Administration Interface for InfluxDB (Collecting data into InfluxDB / Projects)
- awesome-snmp - toni-moreno/snmpcollector - SnmpCollector is a full featured Generic SNMP data collector with Web Administration Interface Open Source tool which has as main goal simplify the configuration for getting data from any device which snmp protocol support and send resulting data to an influxdb backend. (Tools / GUIs)
README
# SnmpCollector [![Go Report Card](https://goreportcard.com/badge/github.com/toni-moreno/snmpcollector)](https://goreportcard.com/report/github.com/toni-moreno/snmpcollector)
SnmpCollector is a full featured Generic SNMP data collector with Web Administration Interface Open Source tool which has as main goal simplify the configuration for getting data from any device which snmp protocol support and send resulting data to an influxdb backend.
For complete information on installation from binary package and configuration you could read the [snmpcollector wiki](https://github.com/toni-moreno/snmpcollector/wiki).
If you wish to compile from source code you can follow the next steps
## Run from master
If you want to build a package yourself, or contribute. Here is a guide for how to do that.### Dependencies
- Go 1.5 for snmpcollector < 0.8
- Go 1.11 for snmpcollector >= 0.8
- NodeJS >=6.2.1### Get Code and setup example config
```bash
git clone https://github.com/toni-moreno/snmpcollector.git
cd snmpcollector
cp conf/sample.config.toml conf/config.toml
```### Building the backend
```bash
go run build.go build
```### Building frontend and backend in production mode
```bash
npm install
PATH=$(npm bin):$PATH # or export PATH=$(npm bin):$PATH depending on your shell
npm run build:prod # will build fronted and backend
```### Creating minimal package tar.gz
After building frontend and backend you wil do
```bash
npm run postbuild #will build fronted and backend
```### Creating rpm and deb packages
you will need previously installed the fpm/rpm and deb packaging tools.
After building frontend and backend you will do.```bash
go run build.go latest
```### Running first time
To execute without any configuration you need a minimal config.toml file on the conf directory.```bash
cp conf/sample.config.toml conf/config.toml
./bin/snmpcollector
```This will create a default user with username *adm1* and password *adm1pass* (don't forget to change them!).
### Recompile backend on source change (only for developers)
```bash
go get github.com/unknwon/bra
npm start
```
will init a change autodetect webserver with angular-cli (ng serve) and also a autodetect and recompile process with bra for the backend#### Online config
Now you wil be able to configure metrics/measuremnets and devices from the builting web server at http://localhost:8090 or http://localhost:4200 if working in development mode (npm start)
### Offline configuration.
You will be able also insert data directly on the sqlite db that snmpcollector has been created at first execution on config/snmpcollector.db examples on example_config.sql
```
cat conf/example_config.sql |sqlite3 conf/snmpcollector.db
```