Comparison
3 kinds of TSDBs are compared here.
InfluxDB - Native Time series database
InfluxDB is one of the most popular TSDBs.
Interface: InfluxQL and HTTP API
OpenTSDB and KairosDB - Time series database based on NoSQL
These two DBs are similar, while the first is based on HBase and the second is based on Cassandra. Both of them provides RESTful style API.
Interface: Restful API
TimescaleDB - Time series database based on Relational Database
Interface: SQL
Prometheus and Druid are also famous for time series data management. However, Prometheus focuses data collection, data visualization and alert warnings. Druid focuses on data analysis with OLAP workload. We omit them here.
The above time series databases are compared from two aspects: the feature comparison and the performance comparison.
I list the basic features comparison of these databases.
Legend:
- O: big support greatly
- o: support
- x: not support
- 😦 : support but not very good
- ?: unknown
Basic Features
Details
OpenSource:
- IoTDB uses Apache License 2.0.
- InfluxDB uses MIT license. However, the cluster version is not open sourced.
- KairosDB uses Apache License 2.0.
- TimescaleDB uses Timescale License, which is not free for enterprise.
SQL like:
- IoTDB and InfluxDB support SQL like language. In addition, the integration of IoTDB and Calcite is almost done (a PR has been submitted), which means IoTDB will support Standard SQL soon.
- OpenTSDB and KairosDB only support Rest API, while IoTDB also supports Rest API (a PR has been submitted).
- TimescaleDB uses the SQL the same as PG.
Schema:
IoTDB: IoTDB proposes a . It is quite different from other TSDBs. However, the kind of schema has the following advantages:
In many industrial scenarios, the management of devices are hierarchical, rather than flat. That is why we think a tree based schema is better than tag-value based schema.
In many real world applications, tag names are constant. For example, a wind turbine manufacturer always identify their wind turbines by which country it locates, the farm name it belongs to, and its ID in the farm. So, a 4-depth tree (“root.the-country-name.the-farm-name.the-id”) is fine. You do not need to repeat to tell IoTDB the 2nd level of the tree is for country name, the 3rd level is for farm id, etc.
A path based time series ID definition also supports flexible queries, like “root.*.a.b.*“, where * is wildcard character.
InfluxDB, KairosDB, OpenTSDB are tag-value based, which is more popular currently.
TimescaleDB uses relational table.
Order by time:
Order by time seems quite trivial for time series database. But… if we consider another feature, called align by time, something becomes interesting. And, that is why we mark OpenTSDB and KairosDB unsupported.
Actually, in each time series, all these TSDBs support order data by timestamps.
However, OpenTSDB and KairosDB do not support order data from different timeseries in the time order.
Ok, consider a new case: I have two time series, one is for the wind speed in wind farm1, another is for the generated energy of wind turbine1 in farm1. If we want to analyze the relation between the wind speed and the generated energy, we have to know the values of both at the same time. That is to say, we have to align the two time series in the time dimension.
So, the result should be:
or,
Though the second table format does not align data by the time dimension, it is easy to be implemented in the client-side, by just scanning data row by row.
IoTDB supports the first table format (called align by time), InfluxDB supports the second table format.
Downsampling:
Different from other systems, IoTDB downsamples data in real time, while others serialized downsampled data on disk.
That is to say,IoTDB supports adhoc downsampling data in arbitrary time. e.g., a SQL returns 1 point per 5 minutes and start with 2020-04-27 08:00:00 while another SQL returns 1 point per 5 minutes + 10 seconds and start with 2020-04-27 08:00:01. (InfluxDB also supports adhoc downsampling but the performance is ….. hm)
There is no disk loss for IoTDB.
Fill:
Sometimes we thought the data is collected in some fixed frequency, e.g., 1Hz (1 point per second). But usually, we may lost some data points, because the network is unstable, the machine is busy, or the machine is down for several minutes.
In this case, filling these holes is important. Data scientists can avoid to many so called dirty work, e.g., data clean.
InfluxDB and OpenTSDB only support using fill in a group by statement, while IoTDB supports to fill data when just given a particular timestamp. Besides, IoTDB supports several strategies for filling data.
Slimit:
Slimit means return limited number of measurements (or, fields in InfluxDB). For example, a wind turbine may have 1000 measurements (speed, voltage, etc..), using slimit and soffset can just return a part of them.
Latest value:
As one of the most basic timeseries based applications is monitoring the latest data. Therefore, a query to return the latest value of a time series is very important. IoTDB and OpenTSDB support that with a special SQL or API, while InfluxDB supports that using an aggregation function. (the reason why IoTDB provides a special SQL is IoTDB optimizes the query expressly.)
Conclusion:
Well, if we compare the basic features, we can find that OpenTSDB and KairosDB somehow lack some important query features. TimescaleDB can not be freely used in business. IoTDB and InfluxDB can meet most requirements of time series data management, while they have some difference.
Advanced Features
I listed some interesting features that these systems may differ.
Compression:
- IoTDB supports many encoding and compression for time series, like RLE, 2DIFF, Gorilla, etc.. and Snappy compression. In IoTDB, you can choose which encoding method you want, according to the data distribution. For more info, see .
- InfluxDB also supports encoding and compression, but you can not define which encoding method you want. It just depends on the data type. For more info, see here (opens new window).
- OpenTSDB and KairosDB use HBase and Cassandra in backend, and have no special encoding for time series.
MQTT protocol support:
MQTT protocol is an international standard and widely known in industrial users. only IoTDB and InfluxDB support user using MQTT client to write data.
Running on Edge-side Device:
Nowdays, edge computing is more and more popular, which means the edge device has more powerful computational resources. Deploying a TSDB on the edge side is useful for managing data on the edge side and serve for edge computing. As OpenTSDB and KairosDB rely another DB, the architecture is heavy. Especially, it is hard to run Hadoop on the edge side.
Multi-instance Sync:
Ok, now we have many TSDB instances on the edge-side. Then, how to upload their data to the data center, to form a … data lake (or ocean, river,…, whatever). One solution is to read data from these instances and write the data point by point to the data center instance. IoTDB provides another choice, which is just uploading the data file into the data center incrementally, then the data center can support service on the data.
JDBC driver:
Now only IoTDB supports a JDBC driver (though not all interfaces are implemented), and makes it possible to integrate many other JDBC driver based softwares.
Standard SQL:
As mentioned before, the integration of IoTDB and Calcite is almost done (a PR has been submitted), which means IoTDB will support Standard SQL.
Spark and Hive integration:
It is very important that letting big data analysis software to access the data in database for more complex data analysis. IoTDB supports Hive-connector and Spark connector for better integration.
Writing data to NFS (HDFS): Sharing nothing architecture is good, but sometimes you have to add new servers even your CPU and memory is idle but the disk is full… Besides, if we can save the data file directly to HDFS, it will be more easy to use Spark and other softwares to analyze data, without ETL.
IoTDB supports writing data locally or on HDFS directly. IoTDB also allows user to extend to store data on other NFS.
InfluxDB, KairosDB have to write data locally.
OpenTSDB has to write data on HDFS.
Conclusion:
Performance Comparison
Ok… If you say, “well, I just want the basic features. IoTDB has little difference from others.”. It is somehow right. But, if you consider the performance, you may change your mind.
quick review
- Write:
We test the performance of writing from two aspects: batch size and client num. The number of storage group is 10. There are 1000 devices and each device has 100 measurements(i.e.,, 100K time series total).
- Read:
10 clients read data concurrently. The number of storage group is 10. There are 10 devices and each device has 10 measurements (i.e.,, 100 time series total). The data type is double, encoding type is GORILLA
The IoTDB version is v0.11.1.
Write performance:
- batch size:
10 clients write data concurrently. IoTDB uses batch insertion API and the batch size is distributed from 1ms to 1min (write N data points per write API call).
The write throughput (points/second) is:
Figure 1. Batch Size with Write throughput (points/second) IoTDB v0.11.1
The write delay (ms) is:
Figure 2. Batch Size with Write Delay (ms) IoTDB v0.11.1
- client num:
The client num is distributed from 1 to 50. IoTDB uses batch insertion API and the batch size is 100 (write 100 data points per write API call).
The write throughput (points/second) is:
Figure 3. Client Num with Write Throughput (points/second) IoTDB v0.11.1
Query performance
Figure 4. Raw data query 1 col time cost(ms) IoTDB v0.11.1
Figure 6. Aggregation query time cost(ms) IoTDB v0.11.1
Figure 7. Downsampling query time cost(ms) IoTDB v0.11.1
Figure 8. Latest query time cost(ms) IoTDB v0.11.1
We can see that IoTDB outperforms others.
More details
We provide a benchmarking tool, called IoTDB-benchamrk (https://github.com/thulab/iotdb-benchmark, you may have to use the dev branch to compile it), it supports IoTDB, InfluxDB, KairosDB, TimescaleDB, OpenTSDB. We have an for comparing these systems using the benchmark tool. When we publish the article, IoTDB just entered Apache incubator, so we deleted the performance of IoTDB in that article. But after comparison, some results are presented here.
For InfluxDB, we set the cache-max-memory-size and the max-series-perbase as unlimited (otherwise it will be timeout quickly).
For KairosDB, we set Cassandra’s read_repair_chance as 0.1 (However it has no effect because we just have one node).
All TSDBs run on a server with Intel(R) Core(TM) i7-10700 CPU @ 2.90GHz,(8 cores 16 threads), 32GB memory , 256G SSD and 10T HDD. The OS is Ubuntu 16.04.7 LTS, 64bits.
All clients run on a server with Intel(R) Core(TM) i7-8700 CPU @ 3.20GHz,(6 cores 12 threads), 16GB memory , 256G SSD. The OS is Ubuntu 16.04.7 LTS, 64bits.
From all above experiments, we can see that IoTDB outperforms others hugely. IoTDB has the minimal write latency. The larger the batch size, the higher the write throughput of IoTDB. This indicates that IoTDB is most suitable for batch data writing scenarios. In high concurrency scenarios, IoTDB can also maintain a steady growth in throughput. (12 million points per second may have reached the limit of gigabit network card) In raw data query, as the query scope increases, the advantages of IoTDB begin to manifest. Because the granularity of data blocks is larger and the advantages of columnar storage are used, column-based compression and columnar iterators will both accelerate the query. In aggregation query, we use the statistics of the file layer and cache the statistics. Therefore, multiple queries only need to perform memory calculations (do not need to traverse the original data points, and do not need to access the disk), so the aggregation performance advantage is obvious. Downsampling query scenarios is more interesting, as the time partition becomes larger and larger, the query performance of IoTDB increases gradually. Probably it has risen twice, which corresponds to the pre-calculated information of 2 granularities(3 hours and 4.5 days). Therefore, the queries in the range of 1 day and 1 week are accelerated respectively. The other databases only rose once, indicating that they only have one granular statistics.
We will update this page once we release new version and finish the experiments. We also welcome more contributors correct this article and contribute IoTDB and reproduce experiments.