Resistor is a complement to the InfluxData Kapactor tool https://github.com/influxdata/kapacitor and has 3 functional components.
-
Alert filtering system: it acts as alert filter for diferent WebHooks , it can filter by ALERTID's, time and tags, without need to change tasks variables or template definition. It can exclude alerts only on some devices or a group of them based on tags.
-
Easy alert management: it can deploy alerts based on basic templates.
-
It has and resistor_udf with habilty to inject some tags / fields over datapoints depending on the value for another tag ( by example the deviceid)
If you wish to compile from source code you can follow the next steps
If you want to build a package yourself, or contribute. Here is a guide for how to do that.
- Go 1.5
- NodeJS >=6.2.1
go get github.com/toni-moreno/resistor
cd $GOPATH/src/github.com/toni-moreno/resistor
go run build.go setup (only needed once to install godep)
godep restore (will pull down all golang lib dependencies in your current GOPATH)
npm install
PATH=$(npm bin):$PATH
npm run build:pro #will build fronted and backend
npm run postbuild #will build fronted and backend
You will need previously installed the fpm/rpm and deb packaging tools
go run build.go latest
To rebuild on source change (requires that you executed godep restore)
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
To execute without any configuration you need a minimal config.toml file on the conf directory.
cp conf/sample.resistor.toml conf/resistor.toml
./bin/resistor
cp conf/sample.resinjector.toml conf/resinjector.toml
./bin/resinjector
Resistor alert config are related to the kapacitor templates, So resistor has these enbedded templates, you can generate and also upload to the resistor engine thougth its HTTP API with the generate_templates.sh script, you can setup
export RESISTOR_URL="http://localhost:6090"
export RESISTOR_USER="mysuperadmin_user"
export RESISTOR_PASS="mysuperadmin_pass"
./templates/generate_templates.sh
Now you wil be able to configure metrics/measuremnets and devices from the builting web server at http://localhost:6090 or http://localhost:4200 if working in development mode (npm start)
Resistor depends on InfluxDB and Kapacitor Tools. Be sure you have InfluxDB and Kapacitor Installed. When first executed , you will want.
- Add all your InfluxDB instances.
- Add all your Kapacitor instances. And configure them with the resInjetor UDF, you can do that by adding this config to the [udf .functions] config section at all your /etc/kapacitor/kapacitor.conf files.
[udf.functions.resInjector]
socket = "/tmp/resInjector.sock"
timeout = "10s"
- Build a product/measurment/fields/tags catalog.(with these 2 steps)
- import all your influx catalog first
- Organize measurements by product and product by product_groups then.
- Import The base Templates.
When done you will be ready to create basic alerts for all your products.
(pending)