-
Notifications
You must be signed in to change notification settings - Fork 56
Home
SnmpCollector is an Open Source tool and is full featured Generic SNMP data collector with Web Administration Interface which has as main goal simplify the configuration for getting data from any device which snmp protocol support and send resulting data to a influxdb.
These are the features for the snmp agent and the webui embedded tool
- SNMP versions 1, 2/2c, 3
- Support for gather any SNMP (SMI) data type.
- Support for cooked counters , can compute increments and/or rate conversion
- Support for cooked STRINGS to get any sub-string as integer
- Support for cooked Process data from previously gathered data (these are the supported expressions )
- Gather of SNMP Scalar an Tabular values.
- Support for filtering table rows, based on snmp data conditions (OIDConditions)
- Support for table row filtering,based on fixed rules (fileConditions) --compatibility with influxsnmp tool--
- Support for custom filters from any table (online selectable via webUI)
- Support for multiple conditions (combined in evaluated expressions)
- Support for Override column aliases with custom labels
- Send self monitoring stats to any influxdb
- Support for Influxdb > 1.0
- SQLite/MySQL SQL based configuration
- influxdb complete customized measurements,field and tag names
- Metric OID Condition Counter (to send only counted results of OID conditions)
- Supports for adding, modifying and deleting devices online ( avoids restart the gathering process on the other devices) (> 0.8)
- Complete configuration Interface for all objects
- Snmp web console as snmpget/snmpwalk replacement
- Automatic snmp connectivity check
- Online Runtime data viewer for all gathered metrics.
- Online Configuration reload
- Online device activation/deactivation , and log
- REST API support
- Configuration for Import and Export
- Automatic OID lookup and form completion from MIB database
- token based authentication to enable Remote Authentication via REST API
Head to and download the latest release and Install the suitable package for your distribution
Debian | RedHat | Docker |
---|---|---|
deb - signature | rpm - signature | docker run -d --name=snmpcol_instance00 -p 80:8090 -v /mylocal/conf:/opt/snmpcollector/conf -v /mylocal/log:/opt/snmpcollector/log tonimoreno/snmpcollector |
You can see a list of features and changes in the ChangeLog
Check an feel free to change any of the predefined parameters in the main configuration placed in /etc/snmpcollector/config.toml
Note: Environment variables mapping are only available in 0.8.1+
############################
# General Config
############################
[general]
# InstanceID will be a string identifying the collector , It will be useful when
# more than one running on the same server, this ID will be shown in the WebUI.
# could be set also with SNMPCOL_GENERAL_INSTANCE_ID env var
instanceID = "WAN Communicactions"
# datadir set the directory where the data will be placed , also sqlite db if set as db engine
# if not set the default datadir will be placed in the configuration directory
# could be set also with SNMPCOL_GENERAL_DATA_DIR env var, default $CWD
# datadir = "/var/lib/snmpcollector"
# homedir set the directory where the public web dir will be placed
# if not set the default homedir will be placed in the current directory
# could be set also with SNMPCOL_GENERAL_HOME_DIR env var, default $CWD
# homedir = "/var/lib/snmpcollector"
# there are as many logs as devices configured
# logdir set the Directory path for each device individual log
# could be set also with SNMPCOL_GENERAL_LOG_DIR env var, default $CWD
# logdir = "/var/log/somelogpath"
# logLevel set the main process log level
# valid values: panic,fatal,error,warn,info,debug
# could also be set with SNMPCOL_GENERAL_LOG_LEVEL env var, default info if not set
loglevel = "info"
# Log mode could be "file/console" if console have been selected
# the content for the main snmpcollector.log and http_access.log will
# be writen in stdout
# could be set also with SNMPCOL_GENERAL_LOG_MODE env var
log_mode = "file"
############################
# DataBase Config
############################
[database]
# type sets the sql backend
# valid values sqlite3,mysql
# could be set also with SNMPCOL_DATABASE_DRIVER_TYPE default sqlite3
type = "sqlite3"
# these parameters are only for mysql (use mysql_setup.sql before)
# could be set also with SNMPCOL_DATABASE_SERVER_HOST env var default localhost
# host = 127.0.0.1:3306
# user Username to connect into DB (apply only to mysql/postgresql)
# could be set also with SNMPCOL_DATABASE_USERNAME env var
# user = "snmpcoluser"
# password Password to connect into DB (apply only to mysql/postgresql)
# could also be set with SNMPCOL_DATABASE_PASSWORD env var
# password = "snmpcolpass"
# name sets the database name
# could also be set with SNMPCOL_DATABASE_NAME env var
name = "snmpcollector"
# Log mode could be "none/file/console"
# if console have been selected all the SQL queries will be writen into stdout
# if file queries will be written in the logdir with name "sqllogfile" parameter if set or "sql.log" if not set
# could be set also with SNMPCOL_DATABASE_LOG_MODE env var
log_mode = "none"
# sqllogfile sets the name for a file in the log/ directory where sql backend will write all SQL transactions
# could also be set with SNMPCOL_DATABASE_SQL_LOG_FILE env var
# sqllogfile = "mysql.log"
# debug adds extra verbosity to the SQL log
# could also be set with SNMPCOL_DATABASE_SQL_DEBUG env var
debug = false
############################
# Self Monitorig Config
############################
#config for sending self monitoring metrics to our default influx db
# Sent Measurements will be <prefix>selfmon_gvm with the following fields
# runtime_goroutines
# *mem.alloc
# *mem.mallocs
# *mem.frees
# *gc.total_pause_ns
# *memory.heap
# *gc.pause_per_second
# *gc.pause_per_interval
# *gc.gc_per_second
# *gc.gc_per_interval
[selfmon]
# enable true/false enable/disable self monitoring
# could also be set with SNMPCOL_SELFMON_ENABLED env var
enabled = true
# send data Frequency
# could also be set with SNMPCOL_SELFMON_FREQ env var
freq = 60
# prefix for measurement naming
# could also be set with SNMPCOL_SELFMON_PREFIX env var
prefix = ""
# inherit device tags
# could also be set with SNMPCOL_SELFMON_INHERIT_DEVICE_TAGS env var
inheritdevicetags = true
# adds extra tags to the measurement config should be set as a csv - tag=value1,tag2=value2,...,tagN=valN
# could also be set with SNMPCOL_SELFMON_EXTRATAGS env va
extratags = [ "instance=snmpcollector01" ]
############################
# Embedded WebServer Config
############################
[http]
# listen where webserver will listen waiting for connections
# could also be set with SNMPCOL_HTTP_LISTEN env var
listen = ":8090"
# NOTE: port = 8090 still usable option but DEPRECATED!!
# Admin user to log in the UI
# could also be set with SNMPCOL_HTTP_ADMIN_USER env var
adminuser = "adm1"
# Admin password to log in the UI
# could also be set with SNMPCOL_HTTP_ADMIN_PASSWORD env var
adminpassword = "adm1pass"
# When more than one instance you will need customize the cookie_id allowing navigate to all instances
# could also be set with SNMPCOL_HTTP_COOKIE_ID env var
cookieid ="my_instance_cookie"
After that and if you are using sqlite3 config backend you will be able to start an snmpcollector agent instance with a zero configuration (without devices or metric definitions). It you prefer MySQL you must setup the database first
After mysql install you will have to create the database and configure user credentials over it you could use the following sql.
create database snmpcollector;
GRANT USAGE ON `snmpcollector`.* to 'snmpcoluser'@'localhost' identified by 'snmpcolpass';
GRANT ALL PRIVILEGES ON `snmpcollector`.* to 'snmpcoluser'@'localhost' with grant option;
flush privileges;
If you have any problems please open issue to the snmpcollector team
Open the url http://your_snmpcollector_agent_host:8090/
You will be prompted to insert valid credentials.
Once logged you will see the main Runtime view with a list of devices and it's state.
snmpcollector has not yet support for different users with customized Access control , right now It has only one administrative user that can be customized into the [database] config.toml section with full access to all devices, configurations, runtime , console
Component | Description |
---|---|
Variable Catalog | Add/edit/view Variables to use on STRINGEVAL metric type |
Influx Servers | Add/edit/view InfluxDB servers to store data |
OID Conditions | Add/edit/view OID queries with some conditions to be applied on Metrics and Filters |
SNMP Metrics | Add/edit/view Metrics you want to collect |
Measurements | Add/edit/view Measurements with selected defined Metrics |
Measurement Groups | Add/edit/view groups of Measurements to create easy configuration templates |
Measurement Filters | Add/edit/view Filters to be applied on Measurements and attached to the Device |
Custom Filters | Add/edit/view filters based on a results query |
SNMP Devices | Add/edit/view desired Devices to collect data from |
All components are listed with a table. The list view allows the user to add/modify/view/remove items stored on database.
- Edit Item: enters on modify view allowing to modify components parameters
- Export Item: Allows the user export selected item.
- View Item: Allows the user to see all parameters of selected item
- New Item: Allows the user enter into parameters form to create a new component
- Filter: Allows the user filter all columns. Note: it accepts regex expressions
- Remove Item: Allows the user to remove selected item. When it is clicked it will show to the user elements that would be affected if the item is removed.
- Enable Edit: Allows the user to select different items and remove or change properties of them.
- Items per page: select the maximum items shown at same page
Component | Description |
---|---|
Runtime | View what the agent is collecting and change options on runtime |
Component | Description |
---|---|
Import | Allows the user import data from file |
Export | Allows the user export data from different components |