Skip to content

Commit

Permalink
changed GraphiteClient write to handle epoch as milliseconds and add …
Browse files Browse the repository at this point in the history
…doc accordingly
  • Loading branch information
Serphentas committed Jan 14, 2018
1 parent 5c5e54e commit e8a4c2a
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 4 deletions.
16 changes: 15 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,18 +12,32 @@ npm install graphite

## Usage

Sending data:
You first have to define the Graphite client:

```js
var graphite = require('graphite');
var client = graphite.createClient('plaintext://graphite.example.org:2003/');
```

You can send metrics without a timestamp. The current Unix epoch will then be used in place:

```js
var metrics = {foo: 23};
client.write(metrics, function(err) {
// if err is null, your data was sent to graphite!
});
```

If you wish to set your own timestamp, you must use `Date.now()` (millisecond precision) as parameter and not `Math.floor(Date.now() / 1000)` (second precision), otherwise your metrics will probably get ignored by Graphite:

```js
var metrics = {foo: 23};
var timestamp = Date.now();
client.write(metrics, timestamp, function(err) {
// if err is null, your data was sent to graphite!
});
```

## Todo

* More docs
Expand Down
17 changes: 14 additions & 3 deletions lib/GraphiteClient.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,15 +28,26 @@ GraphiteClient.flatten = function(obj, flat, prefix) {
return flat;
};

/**
* Writes the given metrics to the underlying plaintext socket to Graphite
*
* If no timestamp is given, the current Unix epoch is used (second precision).
*
* If a timestamp is provided, it must have a millisecond precision, otherwise
* Graphite will probably reject the data.
*
* @param {object} metrics
* @param {object} timestamp
* @param {function} cb
*/
GraphiteClient.prototype.write = function(metrics, timestamp, cb) {
if (typeof timestamp === 'function') {
cb = timestamp;
timestamp = undefined;
}

if (timestamp === undefined) {
timestamp = Math.floor(Date.now() / 1000);
}
// cutting timestamp for precision up to the second
timestamp = Math.floor(Date.now() / 1000);

this._carbon.write(GraphiteClient.flatten(metrics), timestamp, cb);
};
Expand Down

0 comments on commit e8a4c2a

Please sign in to comment.