实际区块链状态数据存储在哪里:在内存中,在文件中还是在数据库中?

sub*_*ari 3 bitcoin blockchain ethereum hyperledger decentralized-applications

我有一个查询,每个节点中保存的区块链数据在哪里。在谷歌、StackOverflow 和一些博客上搜索了很长时间后,得到了很多答案:比如:它保存在像 level-DB 或 Rocks-DB 这样的数据库中,有人说它在内存中保存在一个变量中,有人说它保存在一个变量中文件(来自 hyperledger-fabric)。

我想知道,是否有一种特定的方法来存储大多数区块链框架所遵循的块?

或者所有这些框架都选择不同的方法(如文件、内存或 DB)。

我知道有一个保存在数据库中的区块链的当前状态/世界状态。这种当前状态/世界状态与实际区块链完全不同。在当前状态或世界状态下,数据可以被修改,但在实际区块链中块/数据是不可变的。

简而言之,我的问题是:

数据(不可变块)如何存储在区块链中每个完整节点的分类账上?是在内存中、文件中(如 JSON、CSV 文件)还是数据库中

jur*_*rez 6

区块链是一个分布式数据库。这意味着数据分散在节点(参与计算机)周围。每个节点都可以决定如何存储数据(以及是否存储数据)。

当您访问数据时,实际上是在向网络上的节点发送消息。原则上,如果您只想发送交易,则不必在计算机上存储区块链的任何部分。区块链协议保证您可以正确且可信地从接收到的信息片段中重建数据。

对于每个节点,存储完全取决于软件的编写和配置运行方式。对于以太坊和比特币等大型区块链,整个区块链数据约为数百 GB,因此,如果您将软件配置为将其存储在本地,该软件通常会从其他计算机下载大量大文件并将其存储在您的磁盘上。对于某些程序,作者可能更喜欢使用数据库而不是文件。并且在大多数情况下,部分数据会通过操作系统缓存和程序自身的数据结构暂时保存在内存中。


Yur*_*urg 6

比特币节点将原始块数据保存在磁盘上的文件 .bitcoin/blocks/blk*.dat 中。每个 blknnnnnn.dat 的大小为 128MB,截至今天的数据总大小约为 300GB。所有已知区块的元数据都保存在 .bitcoin/blocks/index/nnnnnn.ldb 文件中的 Level DB 文件中。


Atu*_*Atu 5

这取决于节点客户端的实现。几乎所有这些都使用键值存储来提高效率。具体举几个例子:

  • 比特币核心使用 LevelDB
  • GoEthereum(又名 geth)使用 LevelDB
  • Rippled(XRP 客户端)可以配置为使用 RocksDB 或 NuDB