《Node.js区块链开发》——1.4 加密货币可靠吗

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介:

本节书摘来自华章出版社《Node.js区块链开发》一书中的第1章,第1.4节,作者:朱志文  ,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

1. 1.4 加密货币可靠吗

从上面的讨论中,我们可以了解加密货币是怎么回事了,但是你可能仍然会怀疑加密货币的实用性,它真的可靠吗?这是最初很多人都会问的问题。结论当然是可靠的,但是要解释清楚为什么,就要动用很多技术和理论。还好,这些技术和理论,都是目前成熟的技术。您只要认为它们是可靠的,那么下面的解释就很好理解,不然,要想说服自己,接受加密货币比一些网站的数字币更可靠,那还是很难的。

1.去中心化

首先我们需要明白什么是“中心化”。目前,我们通过浏览器浏览的各大网站,都是中心化的,必须有一台或多台服务器,将我们浏览的内容整理好,提供给我们浏览。如果服务器发生了故障,那么我们也就无法访问了。中心化的东西,一切都被某个组织或公司控制着。
去中心化,更确切的说应该称为分布式,是基于P2P网络的,没有一台机器是作为中心化的服务器的功能,(又或者说,任何一台机器都具备中心化的服务器功能,虽为一个问题的两个极端,效果却是一样的)网络中的每一台电脑都是平等的,任何一台掉线、宕机,都不会影响整个网络继续运行。如果大家都信任这个网络,那么这个网络永远都不会死掉,现在的比特币网络基本上就是如此。具体请看第11章中的源码分享。
这是加密货币的交易通道,是网络基础,可以实现无障碍交易。只要可以上网,任何时间、任何地点,都可以介入这个交易网络,把加密货币支付到世界的任何一个角落。

2.加密解密

我们已经有了可以自由通行的路线或航道,但是这些航道安全吗?有没有强盗?被劫持了、破解了,怎么办?更何况,我们这条航道,要通过一家家私人住所(个人或组织的电脑),或许有个黑客正时刻等待出击呢。
这就需要使用严格的加密解密技术。还好,加密解密技术,也是网络世界普遍使用的技术,而且已经成熟使用了这么多年。从理论上讲,加密货币的交易地址、每一笔交易等都是加密解密中的一部分,破解一个毫无意义,全部破解又相当不易,加之P2P网络节点众多,破解一个节点是没有任何价值的,所以加密货币的安全级别应该是目前最高的。
这是加密货币的安全保障。有了这一点,我们才能放心地支付加密货币,而不用担心丢失、被盗,买家才能有支付交易的基础动力。关于加密解密技术,可以阅读第12章以及第四部分的第24章。

3.区块链

我们可以顺利支付了,但是另一个担忧又来了,怎么保证卖家一定收到了,或者一定没有收到?万一卖家赖账,说没有收到钱怎么办?这种信任机制由谁来保证?
回答是区块链。这个才是加密货币的独创,比特币的创新发明,不过区块链使用的技术却是简单的数据库技术(当然,也可以使用文件存储,不过多数应该都是数据库)。区块链的本质就是存储在数据库里的交易数据,其结构是每一条记录都会记录前一条区块头的散列值,从而可以实现往前追溯,直到第一个创世区块。
更重要的是,这个数据库在P2P网络中是分布式存储的,每一个节点都会保存一份复制备份,每一个人都可以公开访问,查看交易记录。也就是说,不仅交易双方能看到交易结果,整个网络节点都能看到,公开、透明、可追溯,让你不得不信。
这是加密货币的信用保障。任何经济行为,若没有信任作为基础,都不可能达成。加密货币这个独创性,为构建公开、透明、可追溯的信用体系打开了一扇大门,各大公司、组织、个人之所以痴迷于加密货币,都是因为这个创新技术背后的无限可能性。后面,我会继续分享亿书区块链的实现,请阅读第16章“区块链”。

4.共识机制

有航道,又安全、可信,是不是这些就足够了?还有一个关键的问题是,这么多节点维护一个相同的数据库,到底哪个节点写入的数据库会被接受,该如何有序地运作呢?还有,发行的加密货币是固定数量的,怎么保证某个节点不“调皮捣蛋”地自己增加数量呢?在利益面前,什么人、什么事情都有可能会出现。
这个问题的解决之道就是所谓的“共识机制”,包括工作量证明机制(PoW)、股权证明机制(PoS)、授权股权证明机制(DPoS)等,类似于大家商讨问题,集体决策时的原则和规矩。这才是加密货币需要重点编码的地方,也是加密货币开发的难点所在。
特别是DPoS机制,基本上就是股份制公司的股东投票机制,亿书使用的就是这种算法机制。具体请阅读第17章。
这是加密货币的运行规则。是将前面的通用技术进行融合创新的地方,若不了解这个部分,区块链开发就无从谈起。
最后,上述技术并不是相互独立的,而是相互配合、相互支撑,通过共识机制成为一个整体,实现了加密货币绝对不用某个机构发行也能保证其绝对安全的支付和交易

相关文章
|
人工智能 JavaScript Oracle
使用 Solidity 和 Node.js 构建简单的区块链预言机
区块链上的预言机是允许区块链世界与来自WEB其余部分的数据交互的框架,将其称为 WEB 2.0 世界。随着智能合约应用的不断扩展,处理独特用例所需的各种数据也将不断扩大。
454 0
使用 Solidity 和 Node.js 构建简单的区块链预言机
|
JavaScript 区块链 数据安全/隐私保护
|
JavaScript 区块链 数据安全/隐私保护