InfluxDB
This article may contain an excessive amount of intricate detail that may interest only a particular audience. Specifically, protocol definitions and deep technical details.(April 2019) |
Developer(s) | InfluxData |
---|---|
Initial release | 24 September 2013 |
Stable release | 2.7.10[1]
/ 15 August 2024 |
Repository | https://github.com/influxdata/influxdb |
Written in | Rust |
Operating system | Cross-platform |
Type | Time series database |
License | MIT, Proprietary |
Website | influxdata.com |
InfluxDB is a time series database (TSDB) developed by the company InfluxData. It is used for storage and retrieval of time series data in fields such as operations monitoring, application metrics, Internet of Things sensor data, and real-time analytics. It also has support for processing data from Graphite.[2]
The latest version of InfluxDB, 3.x, is written in the Rust programming language. Versions 1.x and 2.x are written in Go.
History
[edit]Y Combinator-backed company Errplane began developing InfluxDB as an open-source project in late 2013 for performance monitoring and alerting.[3] Errplane raised an $8.1M Series A financing led by Mayfield Fund and Trinity Ventures in November 2014.[4] In late 2015, Errplane officially changed its name to InfluxData Inc. InfluxData raised Series B round of funding of $16 million in September 2016.[5] In February 2018, InfluxData closed a $35 million Series C round of funding led by Sapphire Ventures.[6] Another round of $60 million was disclosed in 2019.[7] In February of 2023, another $81 million was closed in a Series E round. [8]
Technical overview
[edit]InfluxDB provides an SQL-like language with built-in time-centric functions for querying a data structure composed of measurements, series, and points. Each point consists of several key-value pairs called the fieldset and a timestamp. When grouped together by a set of key-value pairs called the tagset, these define a series. Finally, series are grouped together by a string identifier to form a measurement.
Values can be 64-bit integers, 64-bit floating points, strings, and booleans. Points are indexed by their time and tagset. Retention policies are defined on a measurement and control how data is downsampled and deleted. Continuous Queries run periodically, storing results in a target measurement.
Events
[edit]InfluxData regularly hosts events related to InfluxDB called InfluxDays. The InfluxDays are technical conventions focused on the evolution of InfluxDB on technical and business points of view. Those events take place once a year in three locations: New York, San Francisco or London. The InfluxDays cover a wide variety of different subjects: software engineering and coding talks as well as business-focused and practical workshops. Companies can showcase how they use InfluxDB.
Line protocol
[edit]InfluxDB accepts data via HTTP, TCP, and UDP. It defines a line protocol backwards compatible with Graphite and takes the form:
measurement(,tag_key=tag_val)* field_key=field_val(,field_key_n=field_value_n)* (nanoseconds-timestamp)?
Licensing
[edit]Contributors to InfluxDB need to give InfluxData Inc. the right to license the contributions and the rest of the software in any way, including under a closed-source license. The Contributor License Agreement claims not to be a copyright transfer agreement.[9]
Closed source clustering components
[edit]In May 2016, InfluxData announced that the computer cluster component of InfluxDB would be sold as closed-source software in order to create a sustainable source of funding for the project's development.[10] Community reaction was mixed, with some feeling the move was a "bait and switch".[11]
InfluxDB 3 Limits Open Source Offerings
[edit]InfluxDB 3 Core is InfluxData's open source product and is intentionally designed not to be a replacement for InfluxDB OSS v1 and v2. InfluxDB 3 Core only allows for queries of the past 72 hours and has a 5 database limit. It does not include a data compactor and is not a complete TSDB solution. Purchasing a software license for InfluxDB 3 Enterprise is required to replace InfluxDB OSS v1 and v2 functionality.
References
[edit]- ^ https://docs.influxdata.com/influxdb/v2/reference/release-notes/influxdb/.
{{cite web}}
: Missing or empty|title=
(help) - ^ James Turnbull (1 December 2014). The Art of Monitoring. James Turnbull. pp. 206–. ISBN 978-0-9888202-4-1.
- ^ Lardinois, Frederic (18 March 2013). "Y Combinator-Backed Errplane Launches Comprehensive Performance Monitoring And Alert Service For Web Apps". TechCrunch. Retrieved 3 August 2021.
- ^ Miller, Ron (8 December 2014). "Errplane Snags $8.1M To Continue Building Open Source InfluxDB Time Series Database". TechCrunch. Retrieved 7 September 2016.
- ^ Mannes, John (21 September 2016). "InfluxData closes $16 million Series B led by Battery Ventures to organize IOT data". TechCrunch. Retrieved 13 October 2016.
- ^ Miller, Ron. "InfluxData scores $35 million Series C to expand time series database business". TechCrunch.
- ^ "Notice of Exempt Offering of Securities". US Securities and Exchange Commission. 13 February 2019. Retrieved 3 August 2021.
- ^ "InfluxData Closes Series E Round and Raises $81 Million in Capital". InfluxData Inc. 8 February 2023. Retrieved 4 October 2024.
- ^ "Individual Contributor License Agreement". 5 February 2018.
- ^ "Update on InfluxDB Clustering, High-Availability and Monetization". GitHub. influxdata. 10 March 2016. Retrieved 8 August 2016.
- ^ "I've advocated for and implemented several InfluxDB installations in production ..." Hacker News. 11 March 2016. Retrieved 8 August 2016.