Quorum是一个许可制的以太坊联盟区块链实现,包含了金融巨头JP摩根开发的一个GETH分支版本, 可以在节点之间实现私有和快速的交易。Quorum为保证隐私对节点之间的私有交易进行了专门的设计, 它使用Raft和Istanbul算法实现共识,使用Tessara和Constellation实现节点数据的加密和共享。 在Quorum网络中交易不需要付费,交易的验证是由投票共识算法完成的。总体上来讲Quorum 类似于以太坊,只是它更关注的企业环境下的交易隐私性与可控性,因此每个节点都需要Quorum 网管生成的密钥对。
学习Quorum区块链的最好的办法,就是运行官方提供的7节点示例。虽然有多种方法来搭建7个 节点,我还是建议使用docker,因为这应该是最简单的办法。下面我使用Google云的Ubuntu 18.04。 如果你在本地机器或AWS上有ubuntu,也是一样的。请先确认docker和docker-compose已经 安装就绪。
在下面的演示中,我们要搭建7个Quorum节点,然后考察节点之间的私有交易是如何运作的。
1、搭建节点
运行下面的命令来搭建全部7个节点:
1 | git clone https://github.com/jpmorganchase/quorum-examples.git |
默认情况下,使用Tessera交易管理器和Istanbul BTF共识来搭建Quorum网络。因此为了
修改为Raft共识算法,我们设置环境变量QUORUM_CONSENSUS=raft
,然后启动7个节点
的后台运行。
你可以运行docker ps
来查看每个容器的运行状态以及其ID。需要稍等一会儿以便
容器启动就绪。
2、部署智能合约
如果要快速掌握以太坊区块链开发,推荐汇智网的在线互动课程:
要在节点上部署智能合约,我们需要运行下面的命令进入该节点的geth控制台:
1 | docker exec -it quorum-examples_node1_1 geth attach /qdata/dd/geth.ipc |
命令中的quorum-examples_node1_1
是节点1的容器ID。上面的命令进入节点1的geth控制台,
现在我们可以在控制台中进行操作。
下面我们要运行部署合约的javascript脚本。如果你查看示例代码目录,可以看到在
quorum-examples/examples/7nodes目录下有private-contract.js
和simplestorage.sol
文件。
在geth控制台运行:
1 | > loadScript('/examples/private-contract.js') |
命令执行需要稍等一会儿。一旦部署成功,上面的命令将返回合约地址,记得拷贝下来 或者抄到纸上。上述脚本在节点1上部署了一个简单的状态值为42的存储合约,交易是节点1 和节点7之间私有的,这意味着其他节点将看不到这个状态值。
要验证这一点,我们可以开启节点2的geth终端,使用ABI和合约地址创建合约实例:
1 | > var abi=<Paste ABI here>; |
果然。
现在进入节点7的geth终端,同样使用ABI和合约地址创建合约实例,然后尝试读取状态值:
1 | >contract.get() |
和预期一样。
3、发送私有交易
现在我们尝试在节点7和其他任选节点之间创建一个新的私有交易,调用合约的set()
方法来修改状态值。这需要使用节点的公钥,可以在quorum-examples/examples/7nodes/keys/
目录下找到全部7个节点的对应公钥。
1 | contract.set(4,{from:eth.coinbase,privateFor:["<your preferred node public key>"]}); |
上面的脚本将设置合约状态值为4,并且仅对指定的节点保持可见。你可以打开这些指定节点 的geth终端查看合约状态值,你看到的应该是4。
原文:A Beginner guide to Quorum Blockchain
汇智网翻译整理,转载请标明出处