metrictank

metrics2.0 based, multi-tenant timeseries store for Graphite and friends.

Github星跟蹤圖

Metrictank

Circle CI
Go Report Card
GoDoc

Introduction

Metrictank is a multi-tenant timeseries engine for Graphite and friends.
It provides long term storage, high availability, efficient storage, retrieval and processing for large scale environments.

GrafanaLabs has been running metrictank in production since December 2015.
It currently requires an external datastore like Cassandra or Bigtable, and we highly recommend using Kafka to support clustering, as well
as a clustering manager like Kubernetes. This makes it non-trivial to operate, though GrafanaLabs has an on-premise product
that makes this process much easier.

Features

  • 100% open source
  • Inspired by the Facebook gorilla paper.
    Most notably, the heavily compressed chunks dramatically lower cpu, memory and storage requirements.
  • Writeback RAM cache, serving most data out of memory.
  • Graphite is a first class citizen. As of graphite-1.0.1, metrictank can be used as a graphite CLUSTER_SERVER.
  • Can also act as a Graphite server itself, though the functions processing library is only partially implemented, metrictank proxies requests to Graphite if it can't handle the required processing (for those requests it will degrade to just being the backend storage)
  • Accurate, flexible rollups by storing min/max/sum/count (which also gives us average).
    So we can do consolidation (combined runtime+archived) accurately and correctly,
    unlike most other graphite backends like whisper
  • Flexible tenancy: can be used as single tenant or multi tenant. Selected data can be shared across all tenants.
  • Input options: carbon, metrics2.0, kafka (soon: json or msgpack over http)
  • Guards against excessive data requests
  • Data backfill/import from whisper

Limitations

  • No performance/availability isolation between tenants per instance. (only data isolation)
  • Minimum computation locality: we move the data from storage to processing code, which is both metrictank and graphite.
  • Backlog replaying and queries can be made faster. A Go GC issue may occasionally inflate response times.
  • We use metrics2.0 in native input protocol and indexes, but barely do anything with it yet.
  • can't overwrite old data. We support reordering the most recent time window but that's it. (unless you restart MT)

Interesting design characteristics (feature or limitation... up to you)

  • Upgrades / process restarts requires running multiple instances (potentially only for the duration of the maintenance) and possibly re-assigning the primary role.
    Otherwise data loss of current chunks will be incurred. See operations guide
  • clustering works best with an orchestrator like kubernetes. MT itself does not automate master promotions. See clustering for more.
  • Only float64 values. Ints and bools currently stored as floats (works quite well due to the gorilla compression),
    No text support.
  • Only uint32 unix timestamps in second resolution. For higher resolution, consider streaming directly to grafana
  • No data locality: doesn't seem needed yet to put related series together.

Docs

installation, configuration and operation.

features in-depth

Other

Releases and versioning

  • releases and changelog

  • we aim to keep master stable and vet code before merging to master

  • We're pre-1.0 but adopt semver for our 0.MAJOR.MINOR format. The rules are simple:

    • MAJOR version for incompatible API or functionality changes
    • MINOR version when you add functionality in a backwards-compatible manner, and

    We don't do patch level releases since minor releases are frequent enough.

License

Copyright 2016-2019 Grafana Labs

This software is distributed under the terms of the GNU Affero General Public License.

Some specific packages have a different license:

主要指標

概覽
名稱與所有者grafana/metrictank
主編程語言Go
編程語言Go (語言數: 6)
平台
許可證GNU Affero General Public License v3.0
所有者活动
創建於2015-02-06 07:44:12
推送於2023-08-23 15:17:14
最后一次提交2023-08-23 11:17:13
發布數31
最新版本名稱v1.1 (發布於 2021-01-14 17:01:40)
第一版名稱0.5.0 (發布於 2016-07-15 17:25:08)
用户参与
星數621
關注者數182
派生數106
提交數6.5k
已啟用問題?
問題數793
打開的問題數31
拉請求數1074
打開的拉請求數3
關閉的拉請求數168
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?