Bitcoin
Atomicity – Does Bitcoin Core write blockchain and chain state data atomically?
data:image/s3,"s3://crabby-images/8eb6d/8eb6da7416c188d2d4a99af4d52440d2c819ce7b" alt="Atomicity – Does Bitcoin Core write blockchain and chain state data atomically? Atomicity – Does Bitcoin Core write blockchain and chain state data atomically?"
In particular, when a new block arrives:
-
Are blocks written to disk in an atomic manner so new blocks exist, or do they not exist? (The leader will never see the partially written state)
-
Are summary databases (e.g. chainstate, block-index) written and flushed to disk atomically along with new blocks so that the blockchain file store gets out of sync with the levelDB file store?
-
More generally, can we say that Bitcoin data storage exhibits ACID properties?
-
Are there any plans to change your datastore behavior in this regard?
(I think the answer to 1-3 is no, no, and no. But I’d like to hear more details and your rationale for the status quo.)