Software:eXtremeDB

From HandWiki
Short description: Embedded database management system

eXtremeDB
Developer(s)McObject LLC.
Stable release
8.2 / 2021; 3 years ago (2021)
Operating systemCross-platform
TypeDBMS
LicenseCommercial license
Websitewww.mcobject.com

eXtremeDB is a high-performance, low-latency, ACID-compliant embedded database management system using an in-memory database system (IMDS) architecture and designed to be linked into C/C++ based programs. It works on Windows, Linux, and other real-time and embedded operating systems.

History

eXtremeDB was introduced in 2001 by McObject LLC, targeting embedded systems running in resource-constrained environments (i.e. with limited random-access memory and relatively low-powered central processing units). eXtreme DB has a small code size, only about 150KB. It has native C language application programming interface and available source code. eXtremeDB has a high degree of portability to support the varied processors and operating systems used in embedded systems. Early deployments by customers included integration in digital TV set-top boxes, manufacturing and industrial control systems, and telecom/networking devices. eXtremeDB emerged to manage what industry analysts, and McObject, portray as significant growth in the amount of data managed on such devices.[1][2][3]

Later editions targeted the high-performance non-embedded software market, including capital markets applications (algorithmic trading, order matching engines) and real-time caching for Web-based applications, including social networks and e-commerce.[4]

Product features

Core eXtremeDB engine

eXtremeDB supports the following features across its product family.[5]

Application programming interfaces

Database indexes

Concurrency mechanisms

eXtremeDB supports multiple concurrent users, offering ACID-compliant transactions (as defined by Jim Gray[6]) using either of two transaction managers: a multiple-reader, single writer (MURSIW) locking mechanism, or multiversion concurrency control (MVCC) transaction manager (optimistic non-locking model).[7][8]

Supported data types

eXtremeDB can work with virtually all C language data types including complex types including structures, arrays, vectors, and BLOBs. Unicode is supported.

Security

Optional features

Distributed database management abilities

The eXtremeDB high availability edition supports both synchronous (2-safe) and asynchronous (1-safe) database replication, with automatic failover.[9] eXtremeDB Cluster edition provides for shared-nothing database clustering. eXtremeDB also supports distributed query processing, in which the database is partitioned horizontally and the DBMS distributes query processing across multiple servers, CPUs, and/or CPU cores.[10] eXtremeDB supports heterogeneous client platforms (e.g. a mix of Windows, Linux, and RTOSs) with its clustering and high availability features. A single partitioned database can include shards running on a mix of hardware and OS platforms.

Hybrid storage

eXtremeDB Fusion edition provides the option of persistent storage (disk or flash) for specific tables, via a database schema notation.[11]

Transaction logging

eXtremeDB Transaction Logging edition keeps a record of changes made to the database and uses this log to provide recovery in the event of device or system failure. This edition includes eXtremeDB Data Relay technology that replicates selected changes to external systems such as enterprise applications and database systems.

SQL ODBC/JDBC

The eXtremeSQL edition provides SQL ODBC support in eXtremeDB and a version 4, level 4 JDBC driver.[12][13]

Kernel mode deployment

The eXtremeDB Kernel Mode edition deploys the database system within an operating system kernel, to provide database functions to kernel-based applications logic.[14]

Features for managing market data

eXtremeDB Financial Edition provides features for managing market data (tick data) in applications such as algorithmic trading and order matching.[15] A “sequences” data type supports columnar data layout and enables eXtremeDB to offer the benefits of a column-oriented database in handling time series data. The Financial Edition also provides a library of vector-based statistical functions to analyze data in sequences, and a performance monitor.

Benchmarks

McObject published reports on benchmark tests employing eXtremeDB. Main-Memory vs. RAM-Disk Databases: a Linux-Based Benchmark examined IMDS performance versus that of a traditional on-disk DBMS deployed on a RAM disk, on identical application tasks. The benchmark’s stated goal was to test the thesis that an IMDS streamlined architecture delivers a performance benefit beyond that provided by memory-based storage.[16] Another benchmark, the Terabyte-Plus In-Memory Database System (IMDS) Benchmark, documented IMDS scalability and performance in the size range of large enterprise application (versus embedded systems) databases. For the test, engineers created a 1.17 terabyte, 15.54 billion row database with eXtremeDB on a 160-core SGI Altix 4700 system running SUSE Linux Enterprise Server 9.[17]

In November, 2012 a marketing report was published for Dell servers with Mellanox InfiniBand.[18]

In late 2014, two more audited benchmark reports were dedicated to eXtremeDB Financial Edition. The first, dated October 29, evaluated McObject's DBMS performance on IBM POWER8 hardware, while the second, on November 18, detailed its application in cloud computing. In 2016, an additional report was conducted to gauge the capabilities of the eXtremeDB Financial Edition.[19]

See also

References

  1. Cold, hard data that’s deep, eeProductCenter (EE Times)2/28/05
  2. "Remember the KISS principle? | Forrester Blogs". http://blogs.forrester.com/tech_product_management/2009/11/remember-the-kiss-principle.html.  Forrester Research, 11/13/2009
  3. Re-inventing embedded database technology for embedded systems and intelligent devices. McObject white paper hosted on Scribd.com, 2009
  4. McObject’s New Business Looks Anything Like Embedded, Embedded Software Blog, VDC Research, 6/30/2010
  5. Key eXtremeDB Features, http://www.mcobject.com
  6. Gray, Jim, and Reuter, Andreas (1993), Distributed Transaction Processing: Concepts and Techniques, Morgan Kaufmann, ISBN:1-55860-190-2
  7. McObject updates eXtremeDB real-time database system, Dr. Dobb’s Journal, 11/9/2009
  8. Gerhard Weikum; Gottfried Vossen (2002). "5 Multiversion Concurrency Control". Transactional Information Systems. Morgan Kaufmann. pp. 211–213. ISBN:1-55860-508-8
  9. Database serves five-nines embedded systems, eWeek, 3/12/2003
  10. "In-memory database released in clustering version". http://www.linuxfordevices.com/c/a/News/McObject-ExtremeDB-Cluster/. , LinuxDevices.com, 7/20/2011
  11. McObject releases eXtremeDB Fusion embedded database, Electronic Product News, 5/3/2007
  12. McObject adds ODBC API to eXtremeDB, EE Times, 8/8/2007[|permanent dead link|dead link}}]
  13. "In-memory DBMS boosts Java". http://www.linuxfordevices.com/c/a/News/McObject-ExtremeDB-45/. , SQL, and HA abilities. LinuxDevices.com, 11/16/2011[|permanent dead link|dead link}}]
  14. Kernel mode gets data faster. Embedded Computing Design, 4/3/2008[|permanent dead link|dead link}}]
  15. "eXtremeDB Financial Edition homepage". http://financial.mcobject.com/extremedb-financial-edition/platform/. Retrieved 26 December 2012. 
  16. Examining Main Memory Databases , iApplianceWeb, 1/4/2002
  17. Terabyte-Plus In-Memory Database Benchmark, http://www.mcobject.com
  18. "Securities Technology Analysis Center Web site". http://www.stacresearch.com/mcobject?q=taxonomy/term/461,3. Retrieved 26 December 2012. 
  19. "STAC Report: eXtremeDB & IBM at scale under STAC-M3". STAC web site. May 9, 2016. https://stacresearch.com/news/2016/05/09/XTR160413. 

External links

  • , McObject