DeepDB

DeepDB (also sometimes called DeepSQL near the end of the project) was a proprietary MySQL storage engine designed for OLAP and OLTP workloads. It was designed to be an alternative to the InnoDB storage engine for MySQL. Intended to scale MySQL to large scale data operations, it utilizes adaptive data structures and machine learning algorithms to optimize transactional workloads at a big data scale. Different from classic B+Tree and LSM-Tree based storage engines, DeepDB is built on top of a new tree structure, called CASSI (Continuous Adaptive Sequential Summarization of Info), which dynamically configures the database during runtime to adapt to new hardware deployments. CASSI keeps running the three steps of analysis, adaption, and optimization for high efficiency. Therefore, this storage engine allows enterprises to utilize MySQL without manual configuration under new hardware settings.

History

Deep Information Sciences was founded in 2010 based on research conducted at the University of New Hampshire. After the company went under in 2017, the source code of the DeepDB engine was released as open-source as part of a new Deep Software Foundation holding. A large portion of the source code of the system was a custom C++ implementation of the Java Development Kit software and not related to the DBMS itself.

Data Model

Relational

While the DeepDB storage engine implements a Key/Value model, the data model is fully relational, as specified in MySQL.

Storage Architecture

Disk-oriented

DeepDB runs on POSIX-based disk-oriented file-systems (e.g. SSD/HDD). All files are persistently stored on the disk and it will write data into in-memory files temporarily. DeepDB stores data in 3 forms including on-disk row store tables, in-memory row store tables, and on-disk column store indexes. Instead of organizing in pages, the in-memory row store, which is append-only, is designed to manage single rows as much as possible. The data and indexes on disk in memory are organized into segments, with various sizes. Segments may contain summary data or metadata so that metadata or summary data remain in the cache when the segments are evicted.

The system manages cache usage using adaptive algorithms. Variable-sized segments rather than pages are used to store data. In addition, summary indexing is used to identify relevant segments.

System Architecture

Shared-Everything

DeepDB storage engine is designed as an easy-to-install plugin replacement for MySQL's native InnoDB storage engine. Using DeepDB does not require any application or schema change. It augments MySQL with full ACID compliance and additional machine-learning metrics. The system is architected for complex environments and supports HTAP(Hybrid Transactional Processing).

Logging

Not Supported

Joins

Nested Loop Join

DeepDB is a storage engine full compatible with other components in MySQL. Thus, it supports the same join algorithms as MySQL, including the Nested-Loop Join Algorithm and the Block Nested-Loop Join Algorithm.

Storage Organization

Copy-on-Write / Shadow Paging

A shadow copy is maintained for recovery on the system crash. Disk snapshots are maintained to roll forward and back in data history. All database files including indexes, transactional state, and metadata are streamed append-only files. Therefore, they provide real-time, incremental and continuous backup.

Storage Model

Decomposition Storage Model (Columnar) N-ary Storage Model (Row/Record)

DeepDB supports transactional row storage for OLTP workloads. It also implements segmented column stores to deliver capabilities similar to OLAP databases (column store). Different from traditional column stores that maintain large and monolithic column store files, variable-sized segments are maintained in DeepDB to improve space utilization.

Concurrency Control

Multi-version Concurrency Control (MVCC)

Same as MySQL, it supports Multi-version Concurrency Control.

Query Interface

SQL

DeepDB is designed as a storage engine that is compatible with MySQL. Since it uses the same MySQL API, the query interface is also the same, which supports the standard SQL query interface with several additional extensions.

Compression

Delta Encoding Prefix Compression

There exists prefix compression in indexes. DeepDB keeps compressed data in the cache, and decompress it during operations. The system supports high-levels of compression with a compact representation of keys and delta compression.

DeepDB Logo
Source Code

https://github.com/DeepFound/deep_engine

Developer

Deep Information Sciences, Inc.

Country of Origin

US

Start Year

2010

End Year

2017

Former Name

DeepSQL

Project Type

Commercial, Open Source

Written in

C++

Derived From

MySQL

Licenses

AGPL v3, Proprietary