kdb+
Original author(s) | Arthur Whitney |
---|---|
Developer(s) | KX |
Initial release | 2003 |
Written in | q |
Operating system | Windows, macOS, Linux, Solaris |
Platform | IA-32, x86-64, SPARC |
Available in | English |
Type | relational time series database |
License | Proprietary |
Website | kx |
kdb+ is a column-based relational time series database (TSDB) with in-memory (IMDB) abilities, developed and marketed by KX.[1] The database is commonly used in high-frequency trading (HFT) to store, analyze, process, and retrieve large data sets at high speed.[2] kdb+ has the ability to handle billions of records and analyzes data within a database.[3] The database is available in 32-bit and 64-bit versions for several operating systems.[4] Financial institutions use kdb+ to analyze time series data such as stock or commodity exchange data.[5] The database has also been used for other time-sensitive data applications including commodity markets such as energy trading, telecommunications, sensor data, log data, machine and computer network usage monitoring[6] along with real time analytics in Formula One racing.[7]
Overview
[edit]kdb+ is a high-performance column-store database that was designed to process and store large amounts of data. Commonly accessed data is pushed into random-access memory (RAM), which is faster to access than data in disk storage. Created with financial institutions in mind, the database was developed as a central repository to store time series data that supports real-time analysis of billions of records.[8][1][9] kdb+ has the ability to analyze data over time and responds to queries similar to Structured Query Language (SQL).[2]
Columnar databases return answers to some queries in a more efficient way than row-based database management systems.[5] kdb+ dictionaries, tables and nanosecond time stamps are native data types and are used to store time series data.[5][10]
At the core of kdb+ is the built-in programming language, q, a concise, expressive query array language, and dialect of the language APL.[8] Q can manipulate streaming, real-time, and historical data.[2] kdb+ uses q to aggregate and analyze data, perform statistical functions, and join data sets and supports SQL queries[11] The vector language q was built for speed and expressiveness and eliminates most need for looping structures.[5] kdb+ includes interfaces in C, C++, Java, C#, and Python.[4][5]
History
[edit]In 1998, KX released kdb, a database built on the language K written by Arthur Whitney. In 2003, kdb+ was released as a 64-bit version of kdb. In 2004, the kdb+ tick market database framework was released along with kdb+ taq, a loader for the New York Stock Exchange (NYSE) taq data. kdb+ was created by Arthur Whitney, building on his prior work with array languages.[5]
In April 2007, KX announced that it was releasing a version of kdb+ for Mac OS X. At that time, kdb+ was also available on the operating systems Linux, Windows, and Solaris.[12]
In September 2012, version 3.0 was released. It was optimized for Intel's upgraded processors with support for WebSockets, Globally unique identifiers (GUID)s, and Universally unique identifiers (UUID). Intel's Advanced Vector Extensions (AVX) and Streaming SIMD Extensions 4 (SSE4) 4.2 on the Sandy Bridge processors of the time allowed for enhanced support of the kdb+ system.[3] In June 2013, version 3.1 was released, with benchmarks up to 8 times faster than for older versions.[13]
In March 2020, version 4.0 was released.[14] New features included Multithreaded primitives, Intel Optane DC persistent memory support and Data at Rest Encryption.
References
[edit]- ^ a b Gutierrez, Daniel (January 19, 2015). "Kdb+ and the Internet of Things/Big Data". Inside Big Data. Retrieved June 8, 2016.
- ^ a b c "Kx Systems and High Frequency Trading". The Trading Mesh. June 10, 2011. Archived from the original on December 19, 2018. Retrieved June 8, 2016.
- ^ a b Groenfeldt, Tom (September 24, 2012). "At Kx Systems Big Data Is Old News". Forbes. Retrieved June 8, 2016.
- ^ a b Sbardella, Luca (October 2, 2009). "A first look at kdb+". Quantmind. Retrieved June 8, 2016.
- ^ a b c d e f Eadline, Douglas (September 9, 2014). "Working Down the Column: The Kdb+ Community". Cluster Monkey. Retrieved June 8, 2016.
- ^ Stamper, Jason (September 4, 2014). "Kx Systems readies faster database in push beyond financial services". 451 Research.
- ^ "Williams Racing Announce KX as an Official Supplier". Williams Racing. Retrieved 2023-01-24.
- ^ a b Golovtchenko, Victor (January 1, 2016). "First Derivatives Boosts its KDB+ Software Business with New Acquisition". Finance Magnates. Retrieved June 8, 2016.
- ^ "Kdb+". Itl Group. Retrieved June 8, 2016.
- ^ Crosman, Penny (September 14, 2009). "Kx Offers Nanosecond Timestamps in Updated Database". Information Week. Retrieved June 8, 2016.
- ^ Marlin, Steve (June 19, 2014). "Wall Street Firms Extend 'Big Data; Capabilities". Markets Media. Retrieved June 8, 2016.
- ^ Cohen, Peter (April 17, 2007). "Kdb+ financial database comes to Mac OS X". Macworld. Retrieved June 8, 2016.
- ^ "Kx's kdb+ claims up to 8x faster than any previous STAC M3 benchmarks". Automated Trader. June 11, 2013. Archived from the original on December 19, 2018. Retrieved June 8, 2016.
- ^ Garland, Simon (March 23, 2020). "Kdb+ version 4.0 – faster, more secure". Retrieved December 4, 2021.