那么后端服务器呢?与Medium的后端控制方法不同,在Web 3.0中,你可以编写智能合约,定义你的应用程序的逻辑,并将其部署到去中心化的状态机上。这意味着每个想建立区块链应用的人都会在这个共享状态机上部署他们的代码。
(1)区块链
以太坊区块链经常被吹捧为"世界计算机"。这是因为它是一个全球可访问的,确定性的状态机,由一个点对点的节点网络维护。这个状态机上状态变化是由网络中的对等者所遵循的共识规则所支配的。
因此,换句话说,它被设计成一个世界上任何人都可以访问和写入的状态机。因此,这台机器不属于任何一个单一实体–而是由网络中的每个人共同拥有。
还有一件事要知道:数据智能被写入以太坊区块链–你永远不能更新现有的数据。
(2)智能合约
智能合约是一个在以太坊区块链上运行的程序,定义了区块链上发生的状态变化背后的逻辑。智能合约是用高级语言编写的,如Solidity或Vyper。
由于智能合约代码存储在以太坊区块链上,任何人都可以检查网络上所有智能合约的应用逻辑。
(3)以太坊虚拟机(EVM)
接下来,你有以太坊虚拟机,他执行智能合约中定义的逻辑,并处理这个全球可访问的状态机上发生的状态变化。
EVM不懂Solidity和Vyper这样的高级语言,这些语言用于编写智能合约。相反,你必须将高级语言编译成字节码,然后EVM才能执行。
区块链上的存储
当然,如果你正在建立一个应用程序,所有的智能合约和数据完成在以太坊区块链上,这种架构是合理的。但任何在以太坊上构建过应用程序的人都知道,在区块链上存储所有东西会变得非常昂贵。
请记住,对于以太坊,用户每次向区块链添加新数据时都要付费。这是因为向分散的状态机添加状态会增加维护该状态机的节点的成本。
每次用户的交易需要添加新的状态时,要求用户为使用你的DApp支付额外的费用,这不是最好的用户体验。解决这个问题的一个办法是使用一个分散的链外存储解决方案,如IPFS或Swarm。
IPFS是一个用于存储和访问数据的分布式文件系统。因此,IPFS系统不是将数据存储在一个集中的数据库中,而是将数据分布和存储在一个点对点的网络中。这使得你在需要时很容易检索到它。
IPFS也有一个被称为"文件币"的激励层。这个层激励世界各地的节点来存储和检索这些数据。你可以使用像Infura(为你提供一个IPFS节点)或Pinata(提供一个易于使用的服务,你可以将你的文件"钉在"IPFS上,并采取IPFS的哈希值并将其存储在区块链上)这样的供应商。
Swarm也是类似的,它是一个去中心化的存储网络,担忧一个明显的区别。Filecoin是一个独立的系统,而Swarm的激励系统是内置的,并通过以太坊区块链上的智能合约强制执行,用于存储和检索数据。