Skip to content



RedisTimeSeries is a Redis Module adding a Time Series data structure to Redis.


  • Quick inserts (50K samples per sec)
  • Query by start time and end-time
  • Query by labels sets
  • Aggregated queries (Min, Max, Avg, Sum, Range, Count, First, Last) for any time bucket
  • Configurable max retention period
  • Compaction/Roll-ups - automatically updated aggregated timeseries
  • labels index - each key has labels which will allows query by labels

Using with other tools metrics tools

In the RedisTimeSeries organization you can find projects that help you integrate RedisTimeSeries with other tools, including:

  1. Prometheus - Adapter for Prometheus to use RedisTimeSeries as backend db.
  2. StatsD, Graphite exports using graphiGote protocol.
  3. Grafana - using SimpleJson datasource.

Memory model

A time series is a linked list of memory chunks. Each chunk has a predefined size of samples. Each sample is a tuple of the time and the value of 128 bits, 64 bits for the timestamp and 64 bits for the value.


You can either get RedisTimeSeries setup in a Docker container or on your own machine.


To quickly try out RedisTimeSeries, launch an instance using docker:

docker run -p 6379:6379 -it --rm redislabs/redistimeseries

Build and Run it yourself

You can also build and run RedisTimeSeries on your own machine.


  • build-essential
  • The RedisTimeSeries repository: git clone


cd RedisTimeSeries
git submodule init
git submodule update
cd src
make all


In your redis-server run: loadmodule

For more information about modules, go to the redis official documentation.

Give it a try

After you setup RedisTimeSeries, you can interact with it using redis-cli.

Here we'll create a time series representing sensor temperature measurements. After you create the time series, you can send temperature measurements. Then you can query the data for a time range on some aggregation rule.

With redis-cli

$ redis-cli> TS.CREATE temperature RETENTION 60 LABELS sensor_id 2 area_id 32
OK> TS.ADD temperature:3:11 1548149181 30
OK> TS.ADD temperature:3:11 1548149191 42
OK>  TS.RANGE temperature:3:11 1548149180 1548149210 AGGREGATION avg 5
1) 1) (integer) 1548149180
   2) "30"
2) 1) (integer) 1548149190
   2) "42"

Client libraries

Go Some languages have client libraries that provide support for RedisTimeSeries commands:

Project Language License Author URL
JRedisTimeSeries Java BSD-3 RedisLabs Github
redistimeseries-go Go Apache-2 RedisLabs Github
redistimeseries-py Python BSD-3 RedisLabs Github