Graphite cluster backend with ClickHouse support
Gray components are optional or alternative
Docker images are available on packages page.
- graphite-web 1.1.0
- graphite-web 0.9.15
- graphite-web 1.0.0
- carbonapi 0.14.1+
- carbonzipper (DEPRECATED, is part of carbonapi currently)
Required golang 1.18+
# build binary
git clone https://github.com/lomik/graphite-clickhouse.git
cd graphite-clickhouse
make- Setup Yandex ClickHouse and carbon-clickhouse
- Setup and configure
graphite-clickhouse - Add graphite-clickhouse
host:portto graphite-web CLUSTER_SERVERS
See configuration documentation.
Some HTTP headers are processed specially by the service
Grafana headers: X-Dashboard-Id, X-Grafana-Org-Id, and X-Panel-Id are logged and passed further to the ClickHouse.
Debug headers (see debugging.md for details):
X-Gch-Debug-External-Data- when this header is set to anything and every ofdirectory,directory-perm, andexternal-data-permparameters in[debug]is set and valid, service will save the dump of external data tables in the directory for debug output.X-Gch-Debug-Output- header to enable special processing forformat=carbonapi_v3_pbandformat=jsonrender output.X-Gch-Debug-Protobuf- header enables the original marshallers forprotobufandcarbonapi_v3_pbto check the binary data integrity.
X-Gch-Request-Id- the current request ID.X-Cached-Find- Flag for find cache hit.
By default graphite-web won't connect to CLUSTER_SERVER on localhost. Cheat:
class ForceLocal(str):
def split(self, *args, **kwargs):
return ["8.8.8.8", "8080"]
CLUSTER_SERVERS = [ForceLocal("127.0.0.1:9090")]