Package Exports
- zag-daemon
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (zag-daemon) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
zag-daemon
The daemons aggregate the raw points sent by zag-agent.
It is also responsible for monitoring and alerting, though that functionality is disabled for now.
Service setup
In order to scale, metrics data can be spread across multiple daemons that are
configured as a ring. A list of their address:ports needs to be passed in
as the join option.
require('zag-daemon')(
{ host: "address:port"
, join: ["address:port"]
, db: "postgres://postgres:1234@localhost/postgres"
, env: "prod" or "dev"
, backend: require('zag-backend-pg')
}).on("error", function(err) { })API
zag-agent uses the UDP API.
UDP
The primary protocol for recording metrics is over UDP. Each daemon is running a UDP
server on options.host.
The data should be newline-delimited lines of the form:
<type>:<key>=<value>where
type-counterorhistogram.key-[>| \w/._()+:-]+value- Number. Positive or negative, integer or decimal.
HTTP
POST /api/metrics
The POST body should be in the same format as the UDP data. The points are recorded as the arrive, so the client can just keep sending data down a single connection instead of making repeated requests.