java开源区块链初始化创世区块jdchain服务搭建

 更新时间:2022年02月24日 12:04:27   作者:kl  
这篇文章主要介绍了java开源区块链初始化创世区块jdchain的服务搭建步骤,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步

初始化创世区块

搭建区块链服务第一步就是初始化创世区块,创建账本。生成dchain初始化创世区块有两种方式,一种是通过官方提供的区块链部署工具,在页面上操作初始化,一种是通过初始化脚本创建。目前,部署工具初始化账本功能有限,只支持btfsmart共识算法的节点初始化,如果要支持mq的共识,只能使用初始化账本的脚本创建

第一步、生成公私钥

使用部署工具生成公私钥,虽然部署工具不支持mq共识的账本初始化,但是还是可以用部署工具帮我们创建并维护公私钥,这种方式比使用脚本创建要方便很多。

第二步、准备配置

jdchain初始化账本需要三个配置,账本配置 ledger.init,本地节点配置:local.conf ,共识服务配置:bftsmart.config 或mq.config,其中local.conf是每个共识节点特有的配置,账本和共识服务配置需要同步到每个节点。

更多配置详情参考:https://github.com/blockchain-jd-com/jdchain

第三步、执行初始化脚本

配置准备好后,先找到ledger-init.sh脚本,然后修改其中-i 和-l参数,指定第二步配置好的配置地址。然后依次执行。如果配置正确无误,会提示初始化服务已准备好,按任意键开始初始化账本。这时回车即可,初始化成功后,会在config/init目录下生成ledger-binding.conf文件。启动节点服务就需要这个配置文件

创世区块创建过程

假设有四个共识节点node0、node1、node2、node3、参与共识创建区块,那么node0执行初始化的脚本时的行为如下,其他节点行为是一致的:

1、根据-i和-l参数加载配置

2、创建初始化配置实例

3、校验当前节点公私钥是否匹配(使用私钥生成签名,用公钥验签)

4、初始化账本,实例化本地事务上下文,生成创世交易

5、对初始交易签名,生成当前节点的账本初始化许可(使用当前事务上下文对象的哈希和当前节点私钥生成签名);

6、在所有参与者之间进行第一阶段的共识,请求所有其它参与方的账本创建许可,依次请求node1、node2、node3的/legerinit/permission/接口,对方接口会进行签名校验,和过程3的方式一致

7、使用当前节点事务交易上下文作为哈希校验其他节点返回的接入许可签名,此过程如果失败,会重试16次

8、链接数据库,生成当前节点初始账本

9、在所有参与者之间进行第二阶段的共识,开始请求所有成员的账本创建决定,如果都返回决议创建就提交账本,否则就回滚。此过程也会重试16次

上面创世区块两阶段的共识接口定义如下:

public interface LedgerInitConsensusService {
	/**
	 * 请求账本的初始化许可;
	 * 
	 * @param requesterId
	 *            发起请求的参与者 id;
	 * @param signature
	 *            请求者的私钥对 “id” + “账本种子” 做出的签名;只有签名合法且参与者是初始化配置中的参与方才能获得有效返回,否则将被拒绝;
	 */
	@HttpAction(path = "/legerinit/permission/{requesterId}", method = HttpMethod.POST, contentType = LedgerInitMessageConverter.CONTENT_TYPE_VALUE, responseConverter = PermissionResponseConverter.class)
	LedgerInitProposal requestPermission(@PathParam(name = "requesterId") int requesterId,
			@RequestBody(converter = SignatureDigestRequestBodyConverter.class) SignatureDigest signature);
	/**
	 * 同步账本初始化决议;
	 * 
	 * @param initDecision
	 *            调用者的账本初始化决议;
	 * @return 目标参与方的账本初始化决议;如果目标参与者尚未准备就绪, 则返回 null;
	 */
	@HttpAction(path = "/legerinit/decision", method = HttpMethod.POST, contentType = LedgerInitMessageConverter.CONTENT_TYPE_VALUE, responseConverter = DecisionResponseConverter.class)
	LedgerInitDecision synchronizeDecision(@RequestBody(converter = DecisionRequestBodyConverter.class) LedgerInitDecision initDecision);

}

遇到的问题:在请求其它参与方的账本创建许可时,输出如下异常:

Invalid permission from participant! --[Id=LdeNn8bWuc2DaqAbx3XCQPUf7bdb94PTKFT2E][name=node1.com]
Invalid permission from participant! --[Id=LdeNezcG3rhs31u8UBSwvfMf2BKr1ZkaLKJAG][name=node2.com]
Invalid permission from participant! --[Id=LdeNqxGmBdmEZK6hVeLcnXppW2qnLLKMMiQhN][name=node3.com]

看到这个输出,就代表可以排除公私钥的问题的。因为这个是最后一步许可,交易哈希许可签名验证失败输出的。而交易哈希是根据当前账本上下文创建的,当前账本上下文是根据初始化账本配置装载的,所以最后的问题出在初始化账本的配置上面。我是因为理解错了下面的配置:

# 当前账本交易发送队列主题(不同账本需不同主题)
system.msg.queue.topic.tx=node3-topic

结语

jdchain的各组件设计的比较灵活,如共识实现可以使用bftsmart、RabbitMQ等,底层存储也可以使用本地的rocksdb也可以使用redis等。

如果有特殊的需求也可以自己实现定义的api接口。博主第一天使用的都是默认的的提供者实现,安装部署都比较顺利,今天尝试使用RabbitMQ的共识时遇到了好几个问题,首先是上面的交易许可验签的问题,然后目前官方的基于RabbitMQ的共识,RabbitMQ的链接器不支持带用户认证的mq的配置。不过问题都已解决了,支持amqp的配置代码也已给官方仓库提交pr了,算正式踏入区块链研究之路了

以上就是java开源区块链初始化创世区块jdchain服务搭建的详细内容,更多关于java开源区快联初始化创世区块jdchain的资料请关注脚本之家其它相关文章!

相关文章

  • Java中的迭代和递归详解

    Java中的迭代和递归详解

    这篇文章主要给大家介绍了关于Java中的迭代和递归,文章显示分别介绍了Java中的迭代和递归,而后又介绍了迭代和递归的区别以及数形递归的相关内容,文中介绍的很详细,相信会对大家学习具有一定的参考借鉴价值,有需要的朋友们可以参考借鉴。
    2016-11-11
  • java selenium Selenium IDE介绍及用法

    java selenium Selenium IDE介绍及用法

    本文主要介绍java selenium Selenium IDE,这里整理了相关资料和介绍如何安装 Selenium IDE和使用方法,有需要的小伙伴可以参考下
    2016-08-08
  • SpringBoot-Maven打包压缩瘦身方式

    SpringBoot-Maven打包压缩瘦身方式

    这篇文章主要介绍了SpringBoot-Maven打包压缩瘦身方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • SpringAOP中的通知Advice详解

    SpringAOP中的通知Advice详解

    这篇文章主要介绍了SpringAOP中的通知Advice详解,Spring 的 AOP 功能中一个关键概念是通知Advice与切点Pointcut表达式相关联在特定节点织入一些逻辑,Spring 提供了五种类型的通知,需要的朋友可以参考下
    2023-08-08
  • java RMI详细介绍及实例讲解

    java RMI详细介绍及实例讲解

    这篇文章主要介绍了java RMI详细介绍及实例讲解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • SpringBoot 接口开发教程(httpclient客户端)

    SpringBoot 接口开发教程(httpclient客户端)

    这篇文章主要介绍了SpringBoot 接口开发教程(httpclient客户端),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • java实现文件夹解压和压缩

    java实现文件夹解压和压缩

    这篇文章主要为大家详细介绍了java实现文件夹解压和压缩,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • Java关键字详解之final static this super的用法

    Java关键字详解之final static this super的用法

    this用来调用目前类自身的成员变量,super多用来调用父类的成员,final多用来定义常量用的,static定义静态变量方法用的,静态变量方法只能被类本身调用,下文将详细介绍,需要的朋友可以参考下
    2021-10-10
  • Java8默认方法Default Methods原理及实例详解

    Java8默认方法Default Methods原理及实例详解

    这篇文章主要介绍了Java8默认方法Default Methods原理及实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • Spring @value用法示例详解

    Spring @value用法示例详解

    这篇文章主要介绍了Spring-@value用法详解,为了简化读取properties文件中的配置值,spring支持@value注解的方式来获取,这种方式大大简化了项目配置,提高业务中的灵活性,本文通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2022-08-08

最新评论