mirror of
https://github.com/corda/corda.git
synced 2025-01-20 03:36:29 +00:00
dbce25b575
Fix a bunch of ReST markup errors.
69 lines
3.3 KiB
ReStructuredText
69 lines
3.3 KiB
ReStructuredText
The ledger
|
||
==========
|
||
|
||
.. topic:: Summary
|
||
|
||
* *The ledger is subjective from each peer's perspective*
|
||
* *Two peers are always guaranteed to see the exact same version of any on-ledger facts they share*
|
||
|
||
.. only:: htmlmode
|
||
|
||
Video
|
||
-----
|
||
.. raw:: html
|
||
|
||
<iframe src="https://player.vimeo.com/video/213812040" width="640" height="360" frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>
|
||
<p></p>
|
||
|
||
|
||
The Ledger Data
|
||
---------------
|
||
|
||
In Corda, there is **no single central store of data**. Instead, each node maintains its own database of those facts that it is aware of.
|
||
|
||
The facts that a node knows about are those that it is involved with. For example, if there are nodes representing Alice and Bob on the network and Alice loans Bob some money, both Alice and Bob will store an identical record of the facts about that loan. If the only parties involved with the loan are Alice and Bob, then they will be the only nodes that ever see or store this data.
|
||
|
||
**Important:** The result of this design is that each peer only sees a subset of facts on the ledger, and no peer is aware of the ledger in its entirety.
|
||
|
||
Example: A network with five nodes, where each numbered circle on an intersection represents a fact shared between two or more nodes.
|
||
|
||
.. image:: resources/ledger-venn.png
|
||
:scale: 25%
|
||
:align: center
|
||
|
||
The preceding Venn diagram represents 5 nodes (Alice, Bob, Carl, Demi and Ed) as sets. Where the sets overlap are shared facts, such as those known by both Alice and Bob (1 and 7).
|
||
|
||
Notably, in this Venn diagram, Alice only shares facts with Bob. Alice does not share facts with any of Carl, Demi or Ed.
|
||
|
||
**Summary**
|
||
|
||
The Corda Ledger is a **subjective** construct from each peer's point of view.
|
||
|
||
**What does that mean?**
|
||
|
||
* There are no omniscient peers who can see everything on the ledger.
|
||
* Each node sees their own facts, and the facts that they share with others.
|
||
|
||
For example, Alice and Demi don't share any facts, so they each see a completely different set of shared facts.
|
||
|
||
Shared Facts
|
||
------------
|
||
|
||
In the previous diagram, we could see that although Carl, Demi and Ed are aware of shared fact 3, **Alice and Bob are not**.
|
||
|
||
On Corda, there is no central or general ledger operating with agency on behalf of all of the nodes on the network. Instead, each node on the network maintains its own vault containing all of its known facts.
|
||
|
||
You can think of this vault as being a database or simple table.
|
||
|
||
.. image:: resources/ledger-table.png
|
||
:scale: 100%
|
||
:align: center
|
||
|
||
Where the rows are shared between nodes (facts 1 and 7 in this example), these are shared facts.
|
||
|
||
Corda guarantees that whenever one of these facts is shared by multiple nodes on the network, it evolves in lockstep in the database of every node that is aware of it. This means that Alice and Bob will both see an **exactly identical version** of shared facts 1 and 7.
|
||
|
||
**Note:** Not all on-ledger facts are shared between peers. For example, Alice's fact 11 is not shared with Bob. Fact 11 could, in fact, not be shared with any other node at all. If this is the case, it is deemed a unilateral fact.
|
||
|
||
**Note:** Although there is no central ledger, it is possible to broadcast a basic fact to all participants should you wish to. You would do this by using the network map service to loop over all parties.De
|