Go to file
Julius Volz a1ba23038e Fix scrape timestamps to reduce sample time jitter.
We're currently timestamping samples with the time at the end of a scrape
iteration. It makes more sense to use a timestamp from the beginning of the
scrape for two reasons:

a) this time is more relevant to the scraped values than the time at the
   end of the HTTP-GET + JSON decoding work.
b) it reduces sample timestamp jitter if we measure at the beginning, and
   not at the completion of a scrape.
2013-04-13 03:45:37 +02:00
appstate Use AST query analyzer and views with tiered storage. 2013-03-21 18:16:52 +01:00
coding Spin up curator run in the tests. 2013-04-05 13:55:11 +02:00
config Allow replacing job targets via HTTP API. 2013-02-28 21:33:29 +01:00
documentation Remove/replace last references to github.com/matttproud/... 2013-02-07 14:32:18 +01:00
model Make LevelDB sample keys fixed-length to ensure correct sort-order. 2013-04-11 18:17:44 +02:00
retrieval Fix scrape timestamps to reduce sample time jitter. 2013-04-13 03:45:37 +02:00
rules Also allow lower-cased aggregation ops. 2013-04-11 18:25:22 +02:00
storage Validate diskFrontier domain for series candidate. 2013-04-09 11:47:16 +02:00
utility Add sort() and sort_desc() expression language functions. 2013-04-10 18:05:45 +02:00
web Merge pull request #134 from prometheus/fix/set-job-label-from-targets-api 2013-04-12 07:28:27 -07:00
.gitignore Include nascent curator scaffolding. 2013-03-25 19:38:14 +01:00
.travis.yml
CONTRIBUTORS.md Update community documentation. 2013-03-28 10:46:41 +01:00
LICENSE Address outstanding comments from PR/47 and other cleanups. 2013-02-07 11:38:01 +01:00
main.go Propagate more errors during rule evaluation. 2013-04-09 13:47:20 +02:00
Makefile Make Travis test runs verbose. 2013-03-28 18:30:24 +01:00
Makefile.TRAVIS Make Travis test runs verbose. 2013-03-28 18:30:24 +01:00
MANIFEST Add MANIFEST listing 3rd party libs and versions. 2013-04-09 13:31:56 +02:00
README.md Include Travis status. 2013-03-28 15:54:40 +01:00

Prometheus

Bedecke deinen Himmel, Zeus! A new kid is in town.

Prometheus is a generic time series collection and computation server that is useful in the following fields:

  1. Industrial Experimentation / Real-Time Behavioral Validation / Software Release Qualification
  2. Econometric and Natural Sciences
  3. Operational Concerns and Monitoring

The system is designed to collect telemetry from named targets on given intervals, evaluate rule expressions, display the results, and trigger an action if some condition is observed to be true.

Prerequisites

  1. Go 1.0.X. GVM is highly recommended as well.
  2. LevelDB: (https://code.google.com/p/leveldb/).
  3. Protocol Buffers Compiler: (http://code.google.com/p/protobuf/).
  4. goprotobuf: the code generator and runtime library: (http://code.google.com/p/goprotobuf/).
  5. Levigo, a Go-wrapper around LevelDB's C library: (https://github.com/jmhodges/levigo).
  6. GoRest, a RESTful style web-services framework: (http://code.google.com/p/gorest/).
  7. Prometheus Client, Prometheus in Prometheus (https://github.com/prometheus/client_golang).
  8. Snappy, a compression library for LevelDB and Levigo (http://code.google.com/p/snappy/).

Getting Started

For basic help how to get started:

Testing

Build Status

License

Apache License 2.0