This project adds a basic high availability layer to InfluxDB.
NOTE: influx-proxy must be built with Go 1.7+, don’t implement udp.
Why
We used InfluxDB Relay before, but it doesn’t support some demands.
We use grafana for visualizing time series data, so we need add datasource for grafana. We need change the datasource config when influxdb is down.
We need transfer data across idc, but Relay doesn’t support gzip.
It’s inconvenient to analyse data with connecting different influxdb.
Therefore, we made InfluxDB Proxy.
Features
Support gzip.
Support query.
Filter some dangerous influxql.
Transparent for client, like cluster for client.
Cache data to file when write failed, then rewrite.
Requirements
Golang >= 1.7
Usage
$ # Install influx-proxy to your $GOPATH/bin
$ go get -u github.com/wilhelmguo/influx-proxy/service
$ go install github.com/wilhelmguo/influx-proxy/service
$ mv $GOPATH/bin/service $GOPATH/bin/influx-proxy
$ # Start influx-proxy!
$ $GOPATH/bin/influx-proxy -config proxy.json
Description
The architecture is fairly simple, one InfluxDB Proxy process and two or more InfluxDB processes. The Proxy should point HTTP requests with measurements to the two InfluxDB servers.
Exact match first. For instance, we use cpu.load for measurement’s name. The KEYMAPS has cpu and cpu.load keys.
It will use the cpu.load corresponding backends.
Then Prefix match. For instance, we use cpu.load for measurement’s name. The KEYMAPS only has cpu key.
It will use the cpu corresponding backends.
InfluxDB Proxy
This project adds a basic high availability layer to InfluxDB.
NOTE: influx-proxy must be built with Go 1.7+, don’t implement udp.
Why
We used InfluxDB Relay before, but it doesn’t support some demands. We use grafana for visualizing time series data, so we need add datasource for grafana. We need change the datasource config when influxdb is down. We need transfer data across idc, but Relay doesn’t support gzip. It’s inconvenient to analyse data with connecting different influxdb. Therefore, we made InfluxDB Proxy.
Features
Requirements
Usage
Description
The architecture is fairly simple, one InfluxDB Proxy process and two or more InfluxDB processes. The Proxy should point HTTP requests with measurements to the two InfluxDB servers.
The setup should look like this:
measurements match principle:
Exact match first. For instance, we use
cpu.loadfor measurement’s name. The KEYMAPS hascpuandcpu.loadkeys. It will use thecpu.loadcorresponding backends.Then Prefix match. For instance, we use
cpu.loadfor measurement’s name. The KEYMAPS only hascpukey. It will use thecpucorresponding backends.Query Commands
Unsupported commands
The following commands are forbid.
GRANTREVOKESupported commands
Only support match the following commands.
.*from.*drop measurement.*show.*measurementsLicense
MIT.