区块链 | 中科院软件研究所发布区块链基础组件RepChain


近日,中国科学院软件研究所发布了一款区块链基础组件——RepChain,全称为Reactive Permission Chain,即采用响应式编程实现自主可控的许可链。据软件发展研究部主任梁赓介绍,该组件以区块链与行业应用结合为目标,在身份准入的基础上建立安全通道,具有标准化、模块化、可视化三大特征,在满足工程实施要求的基础上,可以大幅减少代码量,使开发人员能够轻量化地解决区块链的应用问题。


区块链可称为近年来的热词,刚过去的2016年被称为区块链元年,是中国区块链热度爆发的一年,也是创业公司成立最多的一年。2017年,大家都在探索区块链与行业应用的结合,期待看到成熟的应用案例落地,从而可以走向大规模成熟应用。中科院软件研究所也在积极开展这方面的研究,并研发出这款区块链基础组件,意图为基于区块链的应用开发提供基础功能支持。中科院软件研究所研究员、中科软科技股份有限公司总裁左春表示,“区块链始于去中心化的公有链,而企业级应用需要责任主体,故转向联盟链。其进展徘徊于联盟链平台的公认和流行,以平台的收敛和标准化发展为目标。一旦突破,必带动一系列行业应用的迅猛发展。RepChain将是一个有益的探索方向。” 


企业在将自身业务与区块链结合的过程中,一般不会从最底层开发,而是寻求一个可以定制业务的区块链系统框架,并且能让开发者“易学易用”。RepChain在开发中尽可能采用经过工程实践验证的标准组件,方便第三方改造使用,拥有可视化界面,将复杂的交易传播、出块的过程图形化。


RepChain系统共分为六层,从底层到上层分别是数据层、网络层、共识层、合约层、API层、监控层。数据层负责数据格式定义,并以此为基础实现数据的交换、验证、存储、读取及检索。网络层支持入网许可验证,在此基础上进行去中心化的gossip组网。共识层负责共识模块完成区块的输入共识和输出共识。合约层为共识层提供交易执行环境,具备安全隔离、解释和执行脚本、为脚本执行提供上下文环境和底层API访问的功能。API层提供外部接口,允许第三方应用与系统交互,开发者进行在线测试,提供交易提交、交易检索、区块检索、链检索等基本功能。监控层在区块链网络中收集事件和日志,并将其在前端进行可视化实时状态展示和日志回放。


RepChain的开发目标即是使区块链与行业应用更好融合,RepChain的标准化、模块化、可视化三大特性使其可以适用于多种不同的应用场景。在保险行业领域,RepChain适用于签约环节中的体检结果上链和理赔环节的证据上链共享环节;在数字资产领域,RepChain适用于数字资产分配、持有证明和资产转移等方面;在物联网领域,RepChain适用于嵌入式系统签名和食品溯源。除此之外,在税务、工商、土地等政务服务方面,RepChain也能相应发挥作用。


END


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RepChain(Reactive Permissioned Chain)是第一款采用响应式编程实现的自主可控的许可基础组件,面向企业应用,强调交易的实时性和分布式环境下的柔韧性,且易于根据不同应用场景进行模块定制和弹性部署。其合约设计、可视化设计、接口设计对工程实施提供友好支持。RepChain区块链技术与应用联合实验室、北京连琪科技有限公司和软件所互联网金融技术研究中心共同研发,RepChain1.0已通过“2019可信区块链”功能测试和性能测试,在典型场景获得成功应用,其中“区块链数字不动产证应用”被评选为 “2019可信区块链优秀案例”。 分层架构: 1、数据层:负责数据格式定义,数据结构采用Protocol Buffers定义文件,并以此为基础实现数据的交换、验证、存储、读取及检索 2、网络层:采用JDK内置的TLS实现,支持入网许可验证,在此基础上进行去中心化的gossip组网,网络传播支持P2P和Pub/Sub两种方式 3、共识层:完成区块的输入共识和输出共识。采用兼顾实时性和安全性的CFRD算法,既照顾到交易的实时性要求,又能在一定程度防止节点串通作弊;输入共识对入块的交易顺序达成一致,输出共识对交易顺序执行的结果达成一致 4、合约层:为合约执行提供上下文环境,支持合约的动态部署、运行时加载和编译执行 5、API层:提供外部接口,允许第三方应用以Restful的形式与系统交互,并允许开发者通过Swagger UI进行在线测试。API层提供交易签名提交、区块和交易检索等基本功能 6、监控层:在区块链网络中收集事件/日志,并将其以Protocol Buffers的格式推送至Web端,以H5图形技术进行实时状态的可视化展示和日志回放 安装: install jdk8+ install Python install Scala install SBT install Scala IDE install keystore-explorer ——用于生成密钥对的工具,非必须 install protobuf editor——编辑protobuf定义工具,非必须 运行: git clone https://gitee.com/BTAJL/repchain.git 下载项目到本地 sbt 在项目的根目录下下载项目依赖项,可以配置仓库或者使用阿里镜像 compile 编译成Protocol Buffer Scala类 eclipse 生成eclipse工程文件 打开 Scala IDE, File->Import->Existing Projects,导入项目 右键单击 rep.app.Repchain.scala,Run As->Scala Application(单机组网4个节点) 运行配置VM参数 -Dlogback.configurationFile=conf/logback.xml (使logback配置生效) 查看实时图 http://localhost:8081/web/g1.html RepChain 更新日志: v1.1.0_RC 1、支持OpenJDK(使用13) 推荐使用zulu社区版 2、依赖组件升级 3、组网成员在线增加/删除(节点离网入网时,系统能很快更新节点视图,保证出块不受影响) 节点由于网络故障离线,剩余节点出块不受影响,在网络恢复情况下,节点不需经过人工干预重启即可重新加入到网中,节点恢复加入后,可以继续工作。 节点由于崩溃性故障,需要人工干预重启,节点重启恢复加入后,可以继续工作。 4、共识层抽象和更多的共识算法实现 CFRD PBFT RAFT 5、数据前向兼容 假设系统更新时,Block数据结构追加了新的字段,新的系统代码处理和Block相关的逻辑时,可根据version来做分别的处理,以保证系统对上一个版本的数据可读可处理。 6、存储层抽象 针对不同的共识协议,进行抽象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值