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

简介:

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

1.4 加密货币可靠吗

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

1.去中心化

首先我们需要明白什么是“中心化”。目前,我们通过浏览器浏览的各大网站,都是中心化的,必须有一台或多台服务器,将我们浏览的内容整理好,提供给我们浏览。如果服务器发生了故障,那么我们也就无法访问了。中心化的东西,一切都被某个组织或公司控制着。

去中心化,更确切的说应该称为分布式,是基于P2P网络的,没有一台机器是作为中心化的服务器的功能,(又或者说,任何一台机器都具备中心化的服务器功能,虽为一个问题的两个极端,效果却是一样的)网络中的每一台电脑都是平等的,任何一台掉线、宕机,都不会影响整个网络继续运行。如果大家都信任这个网络,那么这个网络永远都不会死掉,现在的比特币网络基本上就是如此。具体请看第11章中的源码分享。

这是加密货币的交易通道,是网络基础,可以实现无障碍交易。只要可以上网,任何时间、任何地点,都可以介入这个交易网络,把加密货币支付到世界的任何一个角落。

2.加密解密

我们已经有了可以自由通行的路线或航道,但是这些航道安全吗?有没有强盗?被劫持了、破解了,怎么办?更何况,我们这条航道,要通过一家家私人住所(个人或组织的电脑),或许有个黑客正时刻等待出击呢。

这就需要使用严格的加密解密技术。还好,加密解密技术,也是网络世界普遍使用的技术,而且已经成熟使用了这么多年。从理论上讲,加密货币的交易地址、每一笔交易等都是加密解密中的一部分,破解一个毫无意义,全部破解又相当不易,加之P2P网络节点众多,破解一个节点是没有任何价值的,所以加密货币的安全级别应该是目前最高的。

这是加密货币的安全保障。有了这一点,我们才能放心地支付加密货币,而不用担心丢失、被盗,买家才能有支付交易的基础动力。关于加密解密技术,可以阅读第12章以及第四部分的第24章。

3.区块链

我们可以顺利支付了,但是另一个担忧又来了,怎么保证卖家一定收到了,或者一定没有收到?万一卖家赖账,说没有收到钱怎么办?这种信任机制由谁来保证?

回答是区块链。这个才是加密货币的独创,比特币的创新发明,不过区块链使用的技术却是简单的数据库技术(当然,也可以使用文件存储,不过多数应该都是数据库)。区块链的本质就是存储在数据库里的交易数据,其结构是每一条记录都会记录前一条区块头的散列值,从而可以实现往前追溯,直到第一个创世区块。

更重要的是,这个数据库在P2P网络中是分布式存储的,每一个节点都会保存一份复制备份,每一个人都可以公开访问,查看交易记录。也就是说,不仅交易双方能看到交易结果,整个网络节点都能看到,公开、透明、可追溯,让你不得不信。

这是加密货币的信用保障。任何经济行为,若没有信任作为基础,都不可能达成。加密货币这个独创性,为构建公开、透明、可追溯的信用体系打开了一扇大门,各大公司、组织、个人之所以痴迷于加密货币,都是因为这个创新技术背后的无限可能性。后面,我会继续分享亿书区块链的实现,请阅读第16章“区块链”。

4.共识机制

有航道,又安全、可信,是不是这些就足够了?还有一个关键的问题是,这么多节点维护一个相同的数据库,到底哪个节点写入的数据库会被接受,该如何有序地运作呢?还有,发行的加密货币是固定数量的,怎么保证某个节点不“调皮捣蛋”地自己增加数量呢?在利益面前,什么人、什么事情都有可能会出现。

这个问题的解决之道就是所谓的“共识机制”,包括工作量证明机制(PoW)、股权证明机制(PoS)、授权股权证明机制(DPoS)等,类似于大家商讨问题,集体决策时的原则和规矩。这才是加密货币需要重点编码的地方,也是加密货币开发的难点所在。

特别是DPoS机制,基本上就是股份制公司的股东投票机制,亿书使用的就是这种算法机制。具体请阅读第17章。

这是加密货币的运行规则。是将前面的通用技术进行融合创新的地方,若不了解这个部分,区块链开发就无从谈起。

最后,上述技术并不是相互独立的,而是相互配合、相互支撑,通过共识机制成为一个整体,实现了加密货币绝对不用某个机构发行也能保证其绝对安全的支付和交易。

相关文章
|
3月前
|
前端开发 JavaScript 安全
前端JS加密对抗由浅入深-2
前言: 本文主要讲解,针对前端非对称、多段加密数据传输站点,如何进行动态调试,如何进行安全测试。本次讲解不涉及任何漏洞方面,仅为学习探讨,该站点现已经更改加密方式,严禁非法测试!
|
3月前
|
前端开发 JavaScript 安全
前端JS加密对抗由浅入深-1
本文主要讲解,针对前端加密数据传输站点,如何进行动态调试以获取加密算法、秘钥,本次实验不涉及漏洞挖掘,仅为学习演示,环境为本地搭建环境
|
3月前
|
移动开发 JavaScript 安全
js的常见的三种密码加密方式-MD5加密、Base64加密和解密和sha1加密详解总结
js的常见的三种密码加密方式-MD5加密、Base64加密和解密和sha1加密详解总结
101 0
|
25天前
|
Web App开发 JavaScript 前端开发
js开发:请解释什么是Node.js,以及它的应用场景。
Node.js是基于V8的JavaScript运行时,用于服务器端编程。它的事件驱动、非阻塞I/O模型使其在高并发实时应用中表现出色,如Web服务器、实时聊天、API服务、微服务、工具和跨平台桌面应用(使用Electron)。适用于高性能和实时需求场景。
18 4
|
1月前
|
Web App开发 JavaScript 前端开发
深入浅出:Node.js 在后端开发中的应用与实践
【2月更文挑战第13天】本文旨在探讨Node.js这一流行的后端技术如何在现代Web开发中被应用以及它背后的核心优势。通过深入分析Node.js的非阻塞I/O模型、事件驱动机制和单线程特性,我们将揭示其在处理高并发场景下的高效性能。同时,结合实际开发案例,本文将展示如何利用Node.js构建高性能、可扩展的后端服务,以及在实际项目中遇到的挑战和解决方案。此外,我们还将讨论Node.js生态系统中的重要工具和库,如Express.js、Koa.js等,它们如何帮助开发者快速搭建和部署应用。通过本文的探讨,读者将获得对Node.js在后端开发中应用的深入理解,以及如何有效利用这一技术来提升开发效率
|
2月前
|
JavaScript iOS开发 MacOS
掌握NVM、NRM和NPM:Node.js开发的利器
掌握NVM、NRM和NPM:Node.js开发的利器
64 0
|
2月前
|
资源调度 JavaScript 开发工具
从npm慢如蜗牛到飞驰如光:nrm加速你的Node.js开发
从npm慢如蜗牛到飞驰如光:nrm加速你的Node.js开发
111 0
|
3月前
|
小程序
微信小程序|Springboot+Vue+Node开发实现医疗预约挂号系统(二)
微信小程序|Springboot+Vue+Node开发实现医疗预约挂号系统
|
3月前
|
小程序 前端开发 Java
微信小程序|Springboot+Vue+Node开发实现医疗预约挂号系统(一)
微信小程序|Springboot+Vue+Node开发实现医疗预约挂号系统
|
3月前
|
存储 前端开发 JavaScript
JavaScript学习 -- AES加密算法
JavaScript学习 -- AES加密算法
39 0