toni-moreno / resistor

A WebService Based Filter for InfluxData Kapacitor Alerts

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Resistor

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

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
  • NodeJS >=6.2.1

Get Code

go get github.com/toni-moreno/resistor

Building the backend

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)

Building frontend and backend in production mode

npm install
PATH=$(npm bin):$PATH
npm run build:pro #will build fronted and backend

Creating minimal package tar.gz

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

go run build.go latest

Recompile backend on source change (only for developers)

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

Running first time

To execute without any configuration you need a minimal config.toml file on the conf directory.

main resistor tool

cp conf/sample.resistor.toml conf/resistor.toml
./bin/resistor

resistor Injector

cp conf/sample.resinjector.toml conf/resinjector.toml
./bin/resinjector

Setup templates.

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

First Setup Guide

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.

  1. Add all your InfluxDB instances.
  2. 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"
  1. 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.
  1. Import The base Templates.

When done you will be ready to create basic alerts for all your products.

Template naming standars

(pending)

About

A WebService Based Filter for InfluxData Kapacitor Alerts

License:MIT License


Languages

Language:TypeScript 38.3%Language:Go 38.2%Language:HTML 16.5%Language:Shell 3.3%Language:Smarty 2.3%Language:CSS 1.2%Language:JavaScript 0.2%Language:Dockerfile 0.0%