区块链每日问答之节点(1)

区块链节点

区块链节点,通常指的是区块链网络中的计算机,也就是说任何连接到区块链网络的计算机(包括手机,矿机等)都称为节点。比如说比特币网络,是一个公有链,用户在自己的联网电脑上运行比特币程序时,这个电脑就成为比特币区块链网络中的一个节点。是指下载了相关加密货币的节点软件,以参与对等网络的计算机。操作一个节点可以是普通钱包用户,矿工或多人协作。不同的区块链对节点的数量和要求有所不同。通常,节点首先需要具有一定的存储空间,保证足够好的性能以免一跑就堵塞,然后设备需要连接网络,并可以使用矿机、服务器和电脑等进行操作接入区块链,具体使用什么工具视节点要求而定。

区块链节点有何特征:

1、具有存储空间,可以将区块数据存储在TF卡、U盘、移动硬盘和计算机等。

2、连接网络,所有的存储空间的设备必须连接网络。

3、参与区块链,需要在存储空间上运行区块链相应程序,通过可视化终端进行交易。

每一个安装有数字货币客户端并连接到数字货币区块链的电脑就是数字货币区块链的一个有效节点。这个世界上有多少这样的电脑或手机,区块链上就有多少个节点。

下面将对节点要完成的功能,节点的角色,矿池节点,Bitcoin Core,SPV进行进一步介绍.

节点要完成的功能

引用精通比特币上的观点,比特币节点的功能有四个:钱包,挖矿,保存完整区块链,以及路由。

image-20220118210601182

第一个功能是钱包,这里的钱包指的是钱包软件,而非地址加私钥本身。钱包的功能包含收集钱包中的地址相关的 UTXO ,以便统计出地址余额,构建交易,发送交易等等转账相关的功能。

第二个功能是挖矿。挖矿节点会去收集交易,制作区块头,然后参与 POW 算力比拼,找到随机数,生成区块并获得出块奖励和手续费

第三个功能是保存完整区块链。区块链数据庞大,所以并不是所有比特币节点都会下载完整的最新的区块链。

第四个功能是路由。所有类型的节点都会有这个功能。所有的节点有有义务帮助其他节点去验证和扩散交易,去查找其他节点,去维持整个网络的连接。

节点的不同角色

节点是分不同角色的,每个角色的节点都去完成自己所擅长的功能。

image-20220118211105430

第一种角色是普通全节点。一个节点只要是下载了完整且最新的区块链数据,那它就是一个全节点了。全节点当然也拥有路由功能,另外还可能包含或者不包含其他的功能。全节点是整个网络的脊梁,因为只有全节点才能真正自己去验证交易。马上要介绍到的轻节点,本身没有完整的链,所以就不能看到所有的交易历史,不能直接去验证交易,需要通过向全节点去请求必要的交易数据。

第二种角色是 Bitcoin Core 全节点,是功能最为全面的节点。Bitcoin Core 是比特币的参考实现,是比特币网络上最为流行的客户端软件。安装了 Bitcoin Core 的节点,首先是一个全节点,另外还拥有钱包和挖矿的能力。

第三种是 SPV 钱包节点。这种节点的通常只关心和自己钱包中的地址相关部分交易,不会下载完整的区块链,所以也被称为轻节点。钱包通常都是安装在移动设备上,资源有限所以适合使用轻节点。轻节点可以去发起简单支付验证( SPV ),向全节点请求数据来验证交易。

第四种是独立挖矿节点。挖矿节点的主要工作当然是挖矿,独立的,也就是不加人矿池的节点要挖矿是需要下载完整区块链的,所以独立挖矿节点也是全节点。

以上四种就是比特币 P2P 网络上的基本节点角色了。

矿池节点

除了这四类基本节点,涉及到矿池挖矿,还有另外的两种节点。

image-20220118211353048

首先一种是矿池服务器。很多比特币矿工会凑到一起组成矿池来一起挖矿。矿池会搭建专门的矿池服务器来跟比特币的 P2P 网络直接通信,保存了完整的区块链,挖矿节点就只需要跟服务器通信。

另外一种是矿池挖矿节点。虽然也参与挖矿,但是这类节点上只拼命运算,而不会去保存完整的区块链,这样就节约了存储成本。

跟矿池的这种服务器客户机架构类似,钱包也有类似的钱包服务器节点,可以让轻节点通过特定的协议去更加高效的获取最新区块链数据。


关于节点的分类,我们就介绍到这里了。节点要完成四项功能,分别是挖矿,钱包,路由和存储区块链。不同角色的节点也会侧重不同的功能。另外,也不是所有的节点都直接连接到比特币 P2P 网络,例如一些轻钱包节点,或者矿池挖矿节点,会跟特定服务器去通信,这些服务器是比特币的 P2P 网络上的节点。

接下来对上文提到的Bitcoin Core,SPV 进行详细介绍。

Bitcoin Core

当首字母 B 小写的时候,bitcoin 指的是一种加密货币,也就是比特币。当 B 大写的时候,Bitcoin 代表比特币协议或者比特币网络。所谓网络就是由很多台计算机连接成的,每台计算机上都要安装一个软件,那么你猜猜这个软件叫什么名字呢?最早中本聪写这个软件的时候,就把它叫 Bitcoin ,但是后来人为了区分,就把软件的名字改了一下,叫做 Bitcoin Core 。

Bitcoin Core 是一个开源软件

Bitcoin Core 是 Bitcoin 协议的实现,是一个开源软件。

先说什么是实现呢?Bitcoin 作为一套协议,只是规定了游戏规则。这套规则要得到执行就需要有人开发出实实在在的软件,也就是说要有实现,实现是一个术语,英文叫 implementation 。一套协议的实现当然不局限于一个,比特币的实现也有多个,但是 Bitcoin Core 是使用量占绝对优势的实现。

Bitcoin Core 是一个开源软件。软件仓库地址在 https://github.com/bitcoin/bitcoin 。谁,在什么时间,修改了哪一行代码都是一目了然的。我们说比特币是一个真正开放的系统,开放的含义分为很多个层面,代码的开源也就是游戏规则的透明,就是其中的一个层面。

核心功能

接下来,介绍一下 Bitcoin Core 都包含哪些核心功能。

Core 要提供一个节点运行的基础功能。比特币是一个点对点的网络,所以网络上的机器全都是客户端,没有服务器。而 Core 作为客户端上的软件就要承担起维持网络运行的全部职责,其中主要包括:第一,下载并保存完整的比特币区块链。第二,包含一个带图形界面的钱包软件,能够构建并签名交易并广播到整个网络,能够发送和接收比特币。第三,接收网络上的交易,验证交易并打包到区块中,实现挖矿功能。

总之,比特币的功能基本上都要通过 Bitcoin Core 来实现。

背后团队

Bitcoin Core 背后的开发团队是一个人员不断变动的松散组织,不会被任何个人所控制。

最早的开发者只有一个人,就是中本聪。虽然中本聪已经消失多年,但是中本聪开创了很多东西,一直都被继承了下来,例如,使用 C++ 作为主要开发语言,使用 Qt 开发图形界面,使用椭圆曲线密码学等等。直到今天依然有人把 Bitcoin Core 称为中本聪客户端。

后来,团队的领导权又发生了两次变化。接替中本聪的嘉文安德森因为感觉维护项目工作过于琐碎,后来选择了离开。目前的开发由来自不同公司的人共同开展,其中 Blockstream 这个公司享有相对比较多的话语权。

但是,没有任何个体能够操纵比特币的开发。Bitcoin Core 之所以流行是因为在所有的实现中,它最为优秀,如果项目被恶意操控,开发方向偏移,那么矿工们完全可以选择其他的实现去安装。跟其它的开源项目一样,比特币也是一样可以被 fork 的,是一种尊重选择的文化。

总结

Bitcoin Core 是比特币协议的一个实现,是安装在比特币节点上的软件,软件是开源的,没有任何个体能够操纵它的开发,新功能的添加都需要社区首先达成共识。

简单支付验证 SPV

SPV (Simplified Payment Verification),”简单支付验证“,是中本聪在比特币白皮书里面专门介绍的概念,本身其实很简单,但是要事先对区块结构,Merkle Tree 和哈希的概念有理解。

区块结构

一个区块主要由两部分组成,一个是“区块头”( Block Headers ),一个是“区块体”( Block Body ) 。区块头中包含的是关于本区块的一些信息,例如版本号,随机数,挖矿难度等等,其中“前一个区块的哈希”这个是比较有意思的,因为各个区块就是靠这个信息连成一条链的。注意,这里的前一个区块的哈希,其实不是把整个区块数据拿出来算哈希,而只是区块头的哈希。

image-20220118212437248

区块头中另外一项,Merkle 根,是我们更加感兴趣的一个参数。有 Merkle 根,必定对应一个 Merkle 树,必定对应着很多个小数据。没错,每一个小数据就都是一个交易。每个区块中一般都会包含2000多个交易,这些交易的数据并不在区块头中,而是保存在区块体中。注意,区块体中的并没有保存 Merkle 树,区块头中也没有,所以每次如果用到 Markle 树,需要重新运算一下。运算出来的 Merkle 根,就是最终被保存到区块头中的 Merkle 根。

img

理解了区块结构,就可以理解全节点( Full Node )和轻客户端( Thin Client ) 的区别了。全节点是一个程序,例如中本聪自己写的 Bitcoin Coin ,这个程序运行起来之后,会把整条区块链都下载到本地。比特币的区块数据估计到18年底会到达173G ,不算太大,但是要在手机上跑全节点基本是不可能的。所以有轻客户端的概念,例如 Electrum 就是个轻客户端。轻客户端可以安装在电脑上也可以安装在手机上,为啥呢?因为轻客户端只会去下载区块头,每个区块头只有80K,所以一条区块头组成的链,只有几十兆。

SPV 就是一个在轻客户端环境下,验证交易有效性的过程。

SPV 验证过程

安装全节点,很多时候是因为我们要挖矿。而安装轻客户端,通常就是把它当成一个钱包软件用。SPV 要解决的就是在轻客户端条件下的支付确认问题。

钱包当然就是用来负责当前账户的转入和转出操作的。先说转出,轻客户端能构建交易,并且签名交易,再广播到全网,这就是转出操作了。再说转入,网上交易很多,但是轻客户端只会去下载跟自己的账户相关的交易。那么不管是转入还是转出交易,下载到轻客户端本地都是相对孤立的交易,因为本地没有保存区块体。那么如何去验证交易生效了呢?这就是 SPV 要解决的问题。我们知道,一个交易在区块链上生效,意味着要满足两个条件:一个是交易已经被打包到了某个区块中,另外一个是这个区块之上又继续打包了5个区块,也就是所谓的要六次确认。

但是,毕竟轻客户端这里是没有保存任何交易的,所以一个独立的交易拿出来,要确定它属于哪个区块也是不可能的。这时候轻客户端需要发起 SPV 过程。首先,轻客户端要发起一个专门的确认请求,把这个交易广播给网络上邻近的全节点。全节点收到交易后,会去搜索这个交易属于哪个区块,然后会运算这个区块的 Merkle Tree 。这时, Merkle Tree 最大的优势现在就发挥出来了,因为要确认一个交易是不是从属于一个 Merkle 根,是不需要把整个 Merkle Tree 都发送给轻节点的,而只需要发送跟当前交易相关的部分 Merkle 树即可。这样,轻节点接收到这个部分 Merkle 树之后,在自己本地在运算一下这个交易的哈希,然后根据部分 Merkle 树上的各个哈希值,一路运算获得 Merkle 根,如果这个值跟自己的区块头中的正好吻合,交易验证就成功了。

所以整个 SPV 过程是靠全节点帮忙去验证交易的,轻节点自身不能验证交易,但是通过确认其他全节点都接受了这次交易,就间接完成了交易确认。但是,全节点有没有可能反馈一个假的 Merkle Tree 过来呢?答案是不可能。在 Merkle 验证中用一个伪造的交易哈希来得到一个已知的 Merkle 根是不可能的。比特币计算 Merkle 树哈希使用的是 sha256 算法,伪造就相当于去碰撞 sha256 算法了,这是根本不可能的。

SPV 有什么用处?

那么中本聪引入 SPV 技术到底有没有实际用途呢?

首先一个就是用来实现钱包软件。如果一个钱包软件想要安装在移动设备上,想要避免去下载一百多 G 的区块数据。那么就只有两个思路,一个是借助中心化服务器,让钱包去把信息先发送到服务器,然后由服务器去验证交易,这样的思路显然就偏中心化了。另外一个思路就是 SPV ,类似 Electrum 这样的钱包,就可以通过只下载区块头来验证交易,整个的数据量和计算量都是不大的,可以直接运行在低端设备上。所以很多轻客户端,也叫轻钱包,或者叫 SPV 钱包。

SPV 的另外一个用途就是实现侧链技术。侧链就是可以通过双向锚定来使用主链上的币的一条链,上面可以做出各种创新。例如基于比特币的侧链开发出的 RootStock ,可以基于比特币实现智能合约平台。而双向锚定过程,就依赖于 SPV 技术。

所以,虽然 SPV 在白皮书上所占的篇幅不大,但是实际中发挥的作用是非常大的。

总结

最后来总结一下:第一,区块有区块头和区块体组成,区块头中的前一个区块的哈希,其实就是之前一个区块的区块头的哈希,所以单独下载区块头,也能得到一条链。第二,同样是比特币网络上的节点,却可以分成全节点和轻客户端两类,轻客户端就是只下载了区块头。第三,SPV 解决的就是在轻客户端中去确认单独一个交易的过程,总体思路是去相邻的全节点中去请求部分 Merkle 树信息,到本地验证通过,就证明其他的全节点都接受了这个交易。第四,SPV 是开发钱包软件和侧链的关键技术,意义非常重大。

Q&A

  • 全节点和轻节点是什么?

    • **全节点: **拥有全网所有的交易数据的节点

      上文描述的4种节点, 除了SPV都是全节点

    • **轻节点: **只拥有和自己相关的交易数据节点。

      • SPV
  • 独立矿工和合伙矿工

    • 独立矿工:矿工独立生成新的区块,来自区块奖励和交易费用收益全部归自己,承受更高的风险波动和更高的回报(回报周期长)。
    • 合伙矿工:矿工相互联合组成矿池,以发现更多的区块,根据贡献的hash算力共享收益,以更低的风险波动接受较小的回报(回报周期短,目前矿池模式是比特币挖矿的主要模式)。
  • 合伙矿工是什么节点呢 ?

    你们认为呢?

参考

bitcoinbook/ch08.asciidoc at develop · bitcoinbook/bitcoinbook (github.com)

简单支付验证 SPV (happypeter.github.io)

Bitcoin Core (happypeter.github.io)

比特币网络节点分类 - 知乎 (zhihu.com)

Running A Full Node - Bitcoin

轻节点SPV - 知乎 (zhihu.com)

区块链 节点和区块的关系_区块链的轻节点技术_weixin_39786341的博客-CSDN博客

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值