《Node.js区块链开发》——1.4 加密货币可靠吗-阿里云开发者社区

开发者社区> 华章计算机> 正文

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

简介:
+关注继续查看

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

1. 1.4 加密货币可靠吗

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

1.去中心化

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

2.加密解密

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

3.区块链

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

4.共识机制

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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
区块链开发公司发展快 未来主要应用方向怎么走
  区块链应用的核心是去中央和信任,服务佳的区块链应用对凭借智能合同技术的使用,可以自动执行操作,以满足一定的条件,还可以使更多的商品“共享”,大大降低了合同建立和执行的成本。区块链应用同适用于今天蓬勃发展的共享自行车行业,它可能会给该行业带来全新的变化。
1846 0
03.Eclipse下Ndk开发(以文件加密为例模拟一下开发过程)
(创建于2017/12/2) 1.编写native方法 package com.example.ndk_file_encrpty; public class Cryptor { static{ System.
890 0
区块链开发公司浅析未来区块链的发展趋势
 目前,企业的实际应用集中数字货币领域,属于虚拟经济。我们认为,未来的区块链应用将脱虚向实,更多传统企业使用区块链技术来降成本、提升协作效率,激发实体经济增长,是未来一段时间区块链应用的主战场。   与公有链不同,在企业级应用中,大家更关注区块链的管控、监管合规、性能、安全等因素。
1548 0
HyperLedger Fabric区块链开发平台(4.1)
目前区块链开发平台分“公有链平台”和“联盟链系统”两类,“公有链平台”主要以以太坊为主的平台,可以在该类平台上进行代币的发行和根据各种模块搭建应用;“联盟链系统”主要以超级账本为主的开源系统,该类开源系统提供完善的区块链底层技术,开发者只要在其框架下进行二次开发,根据自身需求编写智能合约,通过SDK接口访问区块中的数据,实现具体的区块链业务场景。
1509 0
带你读《区块链开发实战: 基于JavaScript的公链与DApp开发》之二:DApp开发简介
本书用三个部分讲解了区块链技术以及Asch的相关实践,第一部分讲解了区块链技术的基本概念,并用300行代码实现了一个最小的、可运行的区块链;第二部分分析Asch的源码,讲解Asch的实现原理;第三部分介绍了基于Asch的侧链技术的DApp开发实战。
1642 0
《Node.js 实战》预售: 实例讲解 Node.js 在实战开发中的应用
CNode 社区的 4 位大牛合力撰写的 《Node.js 实战》一书,现在当当、京东、亚马逊、互动等各大网店火热预售中。
143 0
带你读《区块链开发实战: 基于JavaScript的公链与DApp开发》之三:Asch——区块链应用开发平台
本书用三个部分讲解了区块链技术以及Asch的相关实践,第一部分讲解了区块链技术的基本概念,并用300行代码实现了一个最小的、可运行的区块链;第二部分分析Asch的源码,讲解Asch的实现原理;第三部分介绍了基于Asch的侧链技术的DApp开发实战。
1566 0
达沃斯直击:区块链与加密货币的命运冰火两重天 | AI金融评论
加密货币与区块链就能如此简单地割裂开来吗?
1064 0
10059
文章
0
问答
来源圈子
更多
+ 订阅
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载