-
Notifications
You must be signed in to change notification settings - Fork 62
Home
Domino v0.1 is released! (06/25/2014)
Domino is a transaction engine implementing SUI on the top of HBase. SUI (State-based Update Isolation) provides distributed concurrency control for bigdata transaction processing and has the ability to prevent the anomalies of P0/P1/P2/P3/P4/A5A.
Domino has the following properties:
- low lock contention;
- one-phase commit;
- lightweight rollback and assistant commit.
These features make Domino support high concurrency and low delay. The TPC-C results shows that Domino achieves high score (tpmC/W=12.24) under distributed environment, which is nearly the same with the performance of Oracle with its dedicated disk array. Domino is open source under Apache License and is currently being integrated into trafodion by HP.
The key contribution of Domino is to design a lock-free concurrency control and one-phase commit (1PC) mechanism for distributed environment. The method is based on our carefully designed data model, which is called \emph{3M data model} (Multi-dimension and Multi-version Map). Our primary idea is to save multiple snapshots for a data item. Every snapshot has two kinds of tags to support full-ACID properties:status and
The above mechanism is called State-based Update Isolation (SUI). Through the correctness verification, we prove that SUI can prevent the following anomalies: P0, P1, P2, P3, P4. In summary, our contributions are enumerated as follows:
\begin{itemize}
\item Multi-dimension and Multi-version Map data model (3M model). 3M model provides the basis for lock-free design.
\item State-based concurrency control (SCC). SCC implements the full-ACID properties preventing the anomalies of P0,P1,P2,P3,P4. SCC also optimises the failure handling through assistant commit and lightweight rollback.
\item One-phase commit (1PC). Unlike the traditional 2PC for distributed environment, the idea of 1PC makes our transaction engine response in real-time.
\end{itemize}
A final note is that we have implemented SUI as a real-world transaction engine, called \emph{Domino}. Domino is an open source software and has been deployed in HP’s production environment. Comprehensive experiments have been performed using TPC-C and YCSB benchmark. The results show that our transaction engine supports high concurrency and low delay with linear scalability.
Domino consists of four components, DETS, TME, DTO and Domino Client. DETS (Domino Endpoint Transaction System) runs on HBase RegionServer with Coprocessor. Therefore, the scalability of DETS is as strong as HBase. The routing protocol is based on the RowKey, which highly saves the maintenance costs. Meanwhile, the routing protocol reduces the most communication between client and server, highly improving the system performance.
Domino also uses Coprocessor Framework to implement DTO (Domino Timestamp Oracle) and TME (Transaction Metadata Endpoint). DTO is responsible for generating increasing transaction id and TME manages the metadata for Domino. Domino client includes HBaseClient and provides APIs for the user.
- public Domino(String zookeeperAddress) throws IOException;
- public Domino(Configuration config) throws IOException;
The APIs is used to manage data table and start a transaction.
Create a Table
- public void createTable(HTableDescriptor table) throws IOException;
- public void createTable(HTableDescriptor table, byte[ ][ ] splitKeys) throws IOException;
-
public void createTable(HTableDescriptor table, byte[ ] startKey, byte[] endKey, int numRegions) throws IOException;
Delete a Table - public void dropTable(byte[ ] name) throws IOException;
-
public Transaction startTransaction() throws IOException;
startTransaction() returns a handler “Transaction” to deal with the transaction.
. Transaction’s commit, rollback, read and write are all provided by Class Transaction.
- Read a record.
public Result get(Get get, byte[ ] table) throws IOException;
This api uses HBase’s ‘Get’ as a parameter, and the result is returned in the format of HBase’s ‘Result’. - Write a stateless record.
public void put(Put put, byte[ ] table) throws IOException; -
Write a stateful record.
public void putStateful(Put put, byte[ ] table) throws IOException; - Delete a record.
public void delete(byte[ ] row, byte[ ] table) throws IOException; - Scan the given range data.
public ResultScanner scan(Scan scan, byte[] table) throws IOException;
This api uses HBase’s Scan as a parameter. - Commit a transaction.
public void commit() throws IOException; - Rollback a transaction.
public void rollback() throws IOException;
An example of how to use domino client can be found at https://github.com/domino-succ/domino/blob/master/example.java.
It is very simple to deploy Domino in the real-world system. The prerequisite is that there should be an executable HBase cluster and the version of HBase should be higher than 0.94.
Domino consist four library files (JARs) as follows:
- domino-client-.jar, the client class library;
- domino-common-.jar, Common class library;
- domino-core-.jar, the core Endpoint class library;
- domino-id-service-.jar, transaction ID service class library.
Before HBase’s startup, we should first put the above four library files (JARs) into HBase’s , and then startup HBase. Follow the above steps, the service of Domino is deployed successfully.
Client side.When using domino at client, we only need to include three jars, domino-client, domino-common and domino-id-service, into . The example how to use the client can be found at https://github.com/domino-succ/domino/blob/master/example.java.
Domino/SUI has the ability to prevent anomalies of P0/P1/P2/P3/P4/A5A, which is the high level isolation for the modern databases. We prove the correctness in our paper.
The TPC-C results shows that Domino achieves high score (tpmC/W=12.24) under distributed environment, which is nearly the same with the performance of oracle with its dedicated disk array.
For more evaluation results, please refer our papers.
Tieying Zhang
Zhen Zhao
Xiaobo Hao
Welcome you to join Domino.
--------------------------------This page is edited by Michael: [email protected]