<aside> đź’¬ This document is open for commenting.

</aside>

Long-term vision

It is easier, cheaper and safer to develop and maintain infinitely scaling high-performance dapps with union-db, than without it.

Goals

<aside> ⚠️ Despite performance being only the third in the list, it is important, even for the first implementation, to provide a powerful improvement basis for the future work.

</aside>

System components

All components of union-db are modular and can be used without the others.

  1. Database state section describes the data structure used in the database, addressing and information related to horizontal scaling.
  2. Queries section describes by example how one can fetch a lot of data from such a database, using regular canister query methods and a little bit of client-side code.
  3. Transactions section describes by example a general purpose distributed transaction engine based on Saga pattern.
  4. Authorization section briefly describes how to protect a multi-canister application against other clients, which may try to intervene into an internal protocol.

Read these sections in the order they are presented here, for best experience:

Database state

Queries

Transactions