Blockchain Meets Database: Design and Implementation of a Blockchain Relational Database
Autor: | Senthil Nathan, Praveen Jayachandran, Chander Govindarajan, Adarsh Saraf, Manish Sethi |
---|---|
Jazyk: | angličtina |
Rok vydání: | 2019 |
Předmět: |
FOS: Computer and information sciences
Blockchain Database Relational database Computer science Serialization General Engineering 020207 software engineering 02 engineering and technology Commit computer.software_genre Database design Computer Science - Distributed Parallel and Cluster Computing 020204 information systems 0202 electrical engineering electronic engineering information engineering Leverage (statistics) Distributed Parallel and Cluster Computing (cs.DC) Snapshot isolation computer Block (data storage) |
Popis: | In this paper, we design and implement the first-ever decentralized replicated relational database with blockchain properties that we term blockchain relational database . We highlight several similarities between features provided by blockchain platforms and a replicated relational database, although they are conceptually different, primarily in their trust model. Motivated by this, we leverage the rich features, decades of research and optimization, and available tooling in relational databases to build a blockchain relational database. We consider a permissioned blockchain model of known, but mutually distrustful organizations each operating their own database instance that are replicas of one another. The replicas execute transactions independently and engage in decentralized consensus to determine the commit order for transactions. We design two approaches, the first where the commit order for transactions is agreed upon prior to executing them, and the second where transactions are executed without prior knowledge of the commit order while the ordering happens in parallel. We leverage serializable snapshot isolation (SSI) to guarantee that the replicas across nodes remain consistent and respect the ordering determined by consensus, and devise a new variant of SSI based on block height for the latter approach. We implement our system on PostgreSQL and present detailed performance experiments analyzing both approaches. |
Databáze: | OpenAIRE |
Externí odkaz: |