国货之光——jdchain1.6.5测试网络部署

简介: 国货之光——jdchain1.6.5测试网络部署

🏠JD Chain

JD Chain是京东数科开源的区块链平台,目标是实现一个面向企业应用场景的通用区块链框架系统,能够作为企业级基础设施,为业务创新提供高效、灵活和安全的解决方案。

JD Chain通过节点实现信息之间的交互,不同类型的节点可以在同一物理服务器上部署运行。JD Chain 中定义了三种不同类型的节点:

1、客户端节点(Client):通过 JD Chain 的 SDK 进行区块链操作的上层应用;
2、网关节点(Gateway):提供网关服务的节点,用于连接客户端和共识节点;
3、共识节点(Peer):共识协议参与方,会产生一致性账本。

一个简单的部署模型如下:

本文对于JD Chain测试网络的部署进行了记录,希望能帮到需要的朋友,本文基于jdchain1.6.5。

jdchain从1.6.3版本起,已支持的共识协议包括:BFTSMART,RAFT,MQ。本文对于这三种共识协议的测试网络分别进行说明。更为详细的安装步骤参考 官方安装文档

🏠准备

👉软件下载

访问 软件下载地址,下载如下安装包

解压文件 jdchain-peer-1.6.5.RELEASE.zip ,进入解压后文件bin目录下,对脚本文件添加可执行权限:

chmod 777 ./*

👉初始化配置参数说明

要搭建一个区块链网络,首先要对其初始化参数进行设置,初始化参数说明如下图所示,后面的所有部署都要用到初始化配置。初始化参数生成后才能进行初始化,进而才能启动各个节点。

不管使用哪种共识协议,部署的总体流程如下:

🏠采用BFT-SMaRt共识协议

👉配置生成

BFT-SMaRt共识协议最少需要4个共识节点,我们就以4个共识节点为例。在上面提到的bin目录下执行如下命令,生成初始化配置:

./jdchain-cli.sh testnet config --algorithm ED25519 --ledger-name mytestnet --password 123456 --peer-zip ../../jdchain-peer-1.6.5.RELEASE.zip --gw-zip ../../jdchain-gateway-1.6.5.RELEASE.zip --consensus BFTSMART --peer-size 4 --init-hosts 127.0.0.1 --peer-hosts 127.0.0.1 --peer-consensus-ports 10080,10082,10084,10086 --peer-manage-ports 7080,7081,7082,7083 --init-ports 8809,8819,8829,8839 --gw-port 8086 --output /home/jdchain/nodes/

执行上述指令,输出如下:

成功创建账本初始化配置文件,会在/home/jdchain/nodes/目录下生成4个peer文件夹(peer0、peer1、peer2、peer3),一个网关gw文件夹。后续操作请确保上诉地址端口未被占用。

👉初始化

这里的初始化,主要是共识节点的初始化。初始化配置生成后,分别进入/home/jdchain/nodes中4个peer*/bin目录下(最好分别开四个客户端),修改shell脚本可执行权限,依次执行初始化脚本:

ledger-init.sh

按照提示操作(等待所有初始化脚本启动之后,有一个按任意键继续的提示,所有节点都需要点击一下确认键),如下图:

节点间在初始化过程中会尝试相互连接,指令执行有先后,所以可忽略初始化过程中的连接错误日志。

要注意,忽略不等于关掉客户端(比如xshell客户端)或者Crtl+C杀掉当前的执行程序,而是保持当前客户端不动,任由其报错,然后新开一个客户端(比如xshell客户端),再进入下一个peer目录进行上面的初始化过程。有多少个peer节点,就重新开启多少个客户端,待所有节点都初始化完成后,每个客户端都会输出如下:

成功执行后会在peer*/config目录下生成ledger-binding.conf文件,表示账本初始化完成。

👉启动

依次进入peer*/bin目录下,修改shell脚本可执行权限,执行

peer-startup.sh

启动peer节点。

进入gw/bin目录下,修改shell脚本可执行权限,执行

startup.sh

启动网关。

访问 服务器IP地址:8086 查看区块链浏览器。输入用户名:jdchain,密码:jdchain,会看到区块链浏览器首页:

至此,采用BFT-SMaRt共识协议的JD Chain部署运行完成。

🏠采用Raft共识协议

采用Raft共识协议部署JD Chain测试网络,只有在初始化配置生成的时候有所不同,后面两步,即初始化和启动的过程,与上面完全一样。这里只给出配置生成的命令。由于采用Raft共识协议支持单节点,我们以单节点模式为例:

./jdchain-cli.sh testnet config --algorithm ED25519 --ledger-name rafttestnet --password 123456 --peer-zip ../../jdchain-peer-1.6.5.RELEASE.zip --gw-zip ../../jdchain-gateway-1.6.5.RELEASE.zip --consensus RAFT --peer-size 1 --init-hosts 127.0.0.1 --peer-consensus-ports 10080 --peer-manage-ports 7080 --init-ports 8809 --gw-port 8086 --output /home/jdchain/raftnodes/

🏠采用MQ共识协议

采用MQ共识协议,首先要保证MQ服务可用,这里以RabbitMQ为例,单节点的配置生成的命令如下:

./jdchain-cli.sh testnet config --algorithm ED25519 --ledger-name mqtestnet --password 123456 --peer-zip ../../jdchain-peer-1.6.5.RELEASE.zip --gw-zip ../../jdchain-gateway-1.6.5.RELEASE.zip --mq rabbitmq://amqp://127.0.0.1:5672 --consensus MQ --peer-size 1 --init-hosts 127.0.0.1 --peer-consensus-ports 10080 --peer-manage-ports 7080 --init-ports 8809 --gw-port 8086 --output /home/jdchain/mqnodes/

后面的初始化和启动过程跟上面两小节的步骤完全相同,这里就不再赘述。

作者这水平有限,有不足之处欢迎留言指正

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
1月前
|
jenkins 测试技术 应用服务中间件
【专业测试技能】全流程掌握:部署测试环境的策略与实践
本文分享了关于部署测试环境的策略与实践。文章讨论了部署测试环境的全过程,包括服务如MySQL、Redis、Zookeeper等的部署,以及解决服务间的依赖和兼容问题。文中还介绍了使用Jenkins、Docker等工具进行部署的方法,并通过实战案例讲解了如何创建和管理Jenkins Job、配置代理服务器Nginx、进行前后端服务的访问和优化。最后,作者强调了提问的重要性,并鼓励大家通过互联网解决遇到的问题。
62 2
【专业测试技能】全流程掌握:部署测试环境的策略与实践
|
1月前
|
SQL 安全 测试技术
网络安全的屏障与钥匙:漏洞防护与加密技术解析软件测试的艺术:探索性测试的力量
【8月更文挑战第27天】在数字时代的海洋中,网络安全是保护我们数据资产的灯塔和堤坝。本文将深入浅出地探讨网络安全领域的关键要素——安全漏洞、加密技术以及不可或缺的安全意识。通过实际案例分析,我们将了解如何识别和修补潜在的安全漏洞,掌握现代加密技术的工作原理,并培养起一道坚固的安全防线。文章旨在为读者提供实用的知识和技能,以便在日益复杂的网络环境中保持警惕,确保个人及组织信息的安全。
|
1月前
|
Kubernetes Devops 持续交付
DevOps实践:使用Docker和Kubernetes实现持续集成和部署网络安全的守护盾:加密技术与安全意识的重要性
【8月更文挑战第27天】本文将引导读者理解并应用DevOps的核心理念,通过Docker和Kubernetes的实战案例,深入探讨如何在现代软件开发中实现自动化的持续集成和部署。文章不仅提供理论知识,还结合真实示例,旨在帮助开发者提升效率,优化工作流程。
|
1月前
|
机器学习/深度学习
神经网络与深度学习---验证集(测试集)准确率高于训练集准确率的原因
本文分析了神经网络中验证集(测试集)准确率高于训练集准确率的四个可能原因,包括数据集大小和分布不均、模型正则化过度、批处理后准确率计算时机不同,以及训练集预处理过度导致分布变化。
|
1月前
|
Web App开发 编解码 Linux
使用Selenium自动化测试解决报告生成失败问题及Linux部署指南
这篇文章介绍了使用Selenium自动化测试解决报告生成失败问题的方法,包括Linux环境下的部署指南和代码实现。
24 1
使用Selenium自动化测试解决报告生成失败问题及Linux部署指南
|
25天前
|
Kubernetes Linux API
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
该博客文章详细介绍了在CentOS 7.6操作系统上使用kubeadm工具部署kubernetes 1.17.2版本的测试集群的过程,包括主机环境准备、安装Docker、配置kubelet、初始化集群、添加节点、部署网络插件以及配置k8s node节点管理api server服务器。
57 0
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
|
29天前
|
敏捷开发 测试技术 持续交付
软件测试中的自动化策略与实践云计算时代的网络安全挑战与对策
【8月更文挑战第30天】在软件开发的海洋中,自动化测试是一艘能够带领团队高效航行的帆船。本文将探讨如何搭建这艘帆船,从选择适合的自动化测试框架开始,到编写有效的测试脚本,再到持续集成的实施和测试结果的分析,我们将一步步揭开自动化测试的神秘面纱。你将学习到如何通过自动化测试来提升软件质量和开发效率,以及如何克服实施过程中的挑战。让我们一起启航,探索自动化测试的世界。
|
1月前
|
网络协议 安全 前端开发
【应用服务 App Service】Azure 应用服务测试网络访问其他域名及请求超时限制(4分钟 ≈ 230秒)
【应用服务 App Service】Azure 应用服务测试网络访问其他域名及请求超时限制(4分钟 ≈ 230秒)
|
1月前
|
网络协议 Windows
在电脑上测试TCP/UDP端口是否开放,还是得网络大佬这招厉害!
在电脑上测试TCP/UDP端口是否开放,还是得网络大佬这招厉害!
|
30天前
|
消息中间件 测试技术 RocketMQ
docker部署RockerMQ单机测试环境
docker部署RockerMQ单机测试环境