本文参照于 https://shuwoom.com/?p=449 以及<<精通比特币>>
区块链网络是去中心化的网络,是一个P2P网络(Peer-to-Peer)网络。网络中不存在中央化的服务和层级结构,每个节点都是对等的节点,各个节点共同提供网络服务。即是客户端,又是服务器。
区块链P2P网络中,虽然每个节点是对等的,但是根据各个节点所提供的功能不同,可以将节点分为几种类型。每个节点都是区块链数据库、网络路由、挖矿和钱包服务的功能集合。
下面是区块链网络中3个重要的角色:
(1)全节点:包含完整区块链、网络路由、矿工和钱包的服务。

(2)矿工:包含完整区块链、网络路由、矿工服务,不包含钱包服务。

(3)轻量钱包(SPV):仅包含网络路由和钱包的服务。

下面我们是考虑一个通用的区块链网络所必须要有的核心场景,实现这些场景,基本上区块链P2P网络的基本原型就出来了。
(1)节点接入P2P网络
(2)矿工、全节点同步区块链(下载最新区块、交易)
(3)轻量钱包创建一笔交易
(4)矿工、全节点接收交易
(5)矿工、全节点挖出新区块,并广播到网络中
(6)矿工、全节点接收广播的区块
在第二部分,我们列举出了区块链P2P网络的6个核心场景,下面我们针对上述6个场景,设计相应的通信协议。
(1)握手通信
一个新节点在刚加入区块链网络的时候,需要对种子节点建立链接,通过种子节点与区块链网络建立联系。这里种子节点可以是网络中公共的DNS种子节点,也可以是自己设定的已知节点地址。

备注:在没有进行握手通信前,是不能进行下面其他操作的。
(2)地址广播及发现
节点在加入区块链网络以后,需要广播自己的地址,让其他网络的节点知道自己的节点信息。同时,与其他相邻节点建立联系。

(3)区块链同步
由于区块链P2P网络中,每个节点都会维护一份区块链数据,但是节点之间维护的数据不一定是最新的,所以需要节点之间同步最新区块链的数据紧张,最终让全网络维护一份一致的区块链数据。

(4)获取某个区块或交易完整信息

(5)检测节点存活

(6)广播一个交易

(7)广播一个区块
