区块链:打开区块链浏览器 数据超好查

前言

随着区块链技术的不断发展和应用落地,大众逐步加深了对区块链技术的认识。我们都知道,区块链具有可追溯、不可篡改等技术特点,那么链上的数据如何查询、溯源呢?这就是我们今天要分享的主角—区块链浏览器。

区块链浏览器:是链上数据可视化的主要窗口,是提供用户浏览与查询区块链所有信息的工具。借助这一窗口,如区块信息、交易信息、账户信息等重要的加密数据得以直观呈现。因此,区块链浏览器对于区块链使用者而言至关重要。以目前国外开源区块链项目以太坊为例,其社区开源浏览器Etherscan承载大量用户流量,是分析链上行为最便捷的工具。

本文将从区块链浏览器研发实操经验切入,与大家交流如何快速构建一个区块链浏览器。

浏览器可以呈现什么?

通过分析一些开源浏览器,我们总结出区块链浏览器展示的典型区块链信息如下几类:

-区块高度

-交易数

-交易趋势

-区块列表

-最近交易列表等

浏览器数据可以直接获取吗?

通常,区块链提供必要的链SDK信息,用以帮助开发者获取链上区块和交易数据,但是其提供的接口往往是基础性的,例如如何获取区块高度、获取某个区块详情、获取某个交易详情等,这些数据直接对应了页面上的区块列表、区块详情、交易详情等基础数据,无法直接通过链SDK获取浏览器所需的的全量信息。

沈阳数字人民币应用场景有望打开:12月2日消息,北京神州数码方圆科技有限公司(以下简称“神州方圆”)与自贸区沈阳片区管委会签署协议,双方将围绕“基于区块链的数字交易平台项目”落地沈阳进行深入合作。该项目以探索数字人民币在沈阳智慧停车等领域的场景应用为切入点,进一步促成京沈两地技术合作,助力沈阳数字经济的多元发展。(沈阳日报)[2021/12/2 12:45:36]

为此,一个好的区块浏览器是需要支持在本地进行链上数据的加工与处理。

首先,通过对不同区块链底层的区块和交易数据等进行监听,当链上产生新区块时,监听系统可通过链SDK第一时间获取该区块的信息;随后,系统将相关数据进行缓存入库,按需设计多种统计逻辑以完成数据的加工统计。因此,区块链浏览器页面上的数据并非直接通过链上SDK直接请求获取,而是源于本地的列表数据和统计数据。

较于通用的直接通过链SDK获取的模式,我们更需要的是一个通过本地缓存区块数据并且加工链上数据的方式来显著提升前端对区块链浏览器数据获取速度,但对于这一方案读者可能会产生两个质疑:

组件是定时获取链上SDK数据的,那就意味着本地数据与链上数据存在时差,这会影响使用体验么?

由于不是链上直接获取,那如何保障本地缓存内的数据真实有效性呢?

针对质疑一,显然这个时差主要源于本地定时获取链上数据的频率,因此通过控制频率范围在合理范围内,就可以实现极短的延时,基本不会影响用户使用浏览器的性能体验。而针对质疑二是本方案中研发设计人员需要重点关注并解决的。

动态 | 腾讯安全:打开文件就中招 “老虎”挖矿木马已感染超5000台电脑:腾讯安全御见威胁情报中心近日监测发现一款通过社会工程术传播的“老虎”挖矿木马。攻击者将木马程序伪装成“火爆新闻”、“内容”、“隐私资料”、“技巧”等虚假文件名,通过社交网络发送到目标电脑,得手后植入大灰狼远控木马等恶意程序,窃取大量用户个人隐私信息,中电脑更可能遭到远程控制。目前,该木马已感染超5000台电脑。因其挖矿使用的自建矿池包含字符“laofubtc”,腾讯安全技术专家将其命名为“老虎”挖矿木马(LaofuMiner)。(腾讯电脑管家)[2019/12/6]

如何保障数据真实有效?

实际上,为了确保数据浏览器数据的真实性,区块浏览器需要增加数据校验模块,即用户可以通过简单的接口调用与区块链进行交互,快速验证数据的真实性。例如,上述校验模块中接口主要包括如下功能:

??区块证明:用于证明特定区块是否在区块链的账本数据中存在;

??交易证明:用于证明特定交易或者交易执行结果是否在区块链账本数据中存在;

??账户证明:用于证明特定账户数据是否在区块链账本数据中存在;

因此通过上述分解,我们可以将整个浏览器的数据获取、加工、校验的流程理解如下:

区块链浏览器设计实操

前面已初步介绍了区块链浏览器的设计思路以及整体运作流程。下面我们以趣链BaaS区块链浏览器为例,详细介绍该区块浏览器的具体设计,如何实现不同区块链的区块及交易数据采集和存储。如下所示,整个自研浏览器组件整体架构如下:

声音 | 浙江现代数字金融科技研究院理事长:数字法币将彻底打开区块链技术应用的国际货币场景:据《财经》杂志昨日消息,浙江现代数字金融科技研究院理事长周子衡刊文近日发文表示,鉴于数字法币的发行与运行,将为区块链技术创新应用提供有效的货币来源与稳定的货币基础,资产数字化的国际途径不仅不会畏缩,反将因之而大为拓展。基于数字法币的数字资产将被层出不穷地开发出来,不仅私人机构,有关当局亦将在国际领域尝试开发于应用以区块链技术为支持的加密数字资产。这就不仅壮大了资产数字化的基础与规模,而且促使资产数字化与支付数字实现国际性的大汇流。特别是在国际汇兑、国际结算等诸领域,数字法币将彻底打开区块链技术应用的国际货币场景,极大地拓展与推进数字金融体系的国际创新。[2019/9/30]

自研浏览器组件架构图

为便于大家理解,我们首先对架构图中的各模块功能进行简单描述:

???数据公共处理层:负责数据存储优化等功能,将在下一篇推文中着重介绍相关的功能设计;

???采集适配层:负责不同区块链数据的采集适配;

???定时服务:负责定时触发采集和统计逻辑,采集器主要通过趣链BaaS的自研链驱动功能实现与不同的区块链底层进行交互并且获取最新的区块和交易数据。其中:

???■采集模块:负责定时主动触发采集逻辑,包括数据处理等功能;

????■统计模块:

??????1)统计模块也是定时服务,定时判断是否有新数据入库;

动态 | 宁波保税区聚焦区块链等新业态 利用数字化转型打开无限市场:今日,宁波日报刊文表示,2019年宁波将利用数字化转型打开无限市场。近年来,宁波保税区聚焦大数据、金融科技、区块链、人工智能、云计算等新业态,规划建设金融科技(区块链)产业园、阿里巴巴宁波数字贸易港、跨境供应链结算科技平台等数字经济平台。去年12月,保税区管委会与宁波诺丁汉大学签订合作协议,宣布合作共建宁波首个区块链实验室。[2019/2/15]

??????2)若产生新数据则会触发统计逻辑,如区块数、交易数、合约数、合约调用数等指标统计;

??????3)统计数据将直接入库或者更新已有数据;

现在有了这些介绍,我们就可以将目光聚焦在趣链自研浏览器组件是如何在一个服务里面获取不同区块链的数据。首先,我们对其设计了一个抽象采集层,在具体调用时只需传入趣链BaaS自研的链驱动即可。

例如,以下示例展示了如何获取最新区块接口:

//?Collector?collector?definitiontype?Collector?interface?{??//?GetLatestBlock?获取最新的区块??GetLatestBlock()?(*Block,?error。

随后,通过如何实现趣链区块链平台的区块数据采集代码来实际演示如何运作,

*自建项目`hpc`,创建目录

*进入hpc目录

金色晨讯 | 马云:比特币或是泡沫 区块链是打开金矿的工具 以太坊核心开发者同意引入“ProgPow”算法:1.马云:比特币或是泡沫 区块链则是打开金矿的工具。

2.委内瑞拉希望利用石油币为大型住房计划提供资金。

3.Binance已正式终止部分国家的服务。

4.马耳他管理局实施了加密和DLT监管沙箱的第一阶段。

5.以太坊核心开发者同意引入“ProgPow”算法。

6.英国北爱尔兰威尔森拍卖行将拍卖被查封的167.7枚门罗币。

7.美国得克萨斯州银行监管部门提出以货币标准监管稳定币。

8.2018年的熊市使得主要加密货币的相关性增加。

9.普林斯顿大学正在重启比特币免费在线课程。[2019/1/7]

cd?hpcgo?mod?init?hpctouch?main.go

*成功目录结构如下

.├──?go.mod└──?main.go

*go.mod引入依赖

module?hpc?go?1.17?require?(????git.hyperchain.cn/blocface/chainsdk?v0.0.1)

*main.go编辑,可关注代码注释的补充描述:首先,将自定义实现接口Collector的对象注册进执行器,引入采集器执行器,执行即可;

*注意:若链上没有区块,此方法返回&bs.Block{},nil,各种不同的区块链可通过自定义实现方式来达到采集效果;

package?main?import?(????bs?"git.hyperchain.cn/blocface/chainsdk/pkg/collect/base"??????"git.hyperchain.cn/blocface/chainsdk/pkg/collect/collectinter")?func?main()?{????err?:=?collectinter.Register(mockImp{})????if?err?!=?nil?{????????panic(err)????}????collectinter.Execute(。?type?mockImp?struct?{}??func?(m?mockImp)?GetLatestBlock()?(*bs.Block,?error)?{????panic("自定义实现获取最新区块"。

*工具包中提供信息对象,如提供节点或者链的相关信息

type?Base?struct?{????node?string?????Node?struct?{????????Name?????????????string?????????Type?????????????string?????????Host?????????????string????????Ports????????????string?????????UniqueName???????string?????}??????????????????????????Channel????????string??}

*编译打包(平台GOOS=linux架构GOARCH=amd64)

??GOOS=linux?GOARCH=amd64?go?build?-ldflags="-w?-s"?-gcflags="all=-N?-l"?-o?hpc?.

通过上述步骤,我们实现了趣链区块链平台的区块数据采集,随后,我们只需在趣链自研浏览器组件中调用引入相关的客户端包,根据驱动二进制的路径新建客户端即可。

//NewChainClientnewchainclientfuncNewChainClient(tool,channel,cfgRootPathstring,nodebase.Node,opts...ClientOpt)(*ChainClient,error){?abs,err:=filepath.Abs(tool)?iferr!=nil{??returnnil,errors.Wrap(err,"getabsolutepath")?}?marshal,err:=json.Marshal(node)?iferr!=nil{??returnnil,errors.Wrap(err,"marshalnode")?}?c:=&ChainClient{??tool:?????abs,??node:?????string(marshal),??channel:????channel,??configRootPath:cfgRootPath,??timeout:????10*time.Second,?}?for_,opt:=rangeopts{??opt(c)?}?returnc,nil}

调用逻辑获取最新区块示例

func?(c?ChainClient)?GetLatestBlock()?(*base.Block,?error)?{??command?:=?fmt.Sprintf("%s?-p?'%s'??-m?GetLatestBlock?",?c.tool,?c.configRootPath)??out,?err?:=?util.NewDefaultCMD(command,?string{},?util.WithTimeout(int(c.timeout.Seconds())),?util.WithForceKill(true),?util.WithErrPrint(false)).Run()??if?err?!=?nil?{????return?nil,?errors.Wrap(err,?"call?GetLatestBlock")??}??out?=?strings.TrimSuffix(out,?"n")??var?b?=?base.Block{}??err?=?deocde(byte(out),?&b)??if?err?!=?nil?{????return?nil,?errors.Wrapf(err,?"decode?resp?",?out)??}??return?&b,?nil}

以下是趣链BaaS的区块链浏览器前端页面,只需调取内部接口就可以直接从数据库中获取所需的信息,我们从区块、交易、合约、账户等多个维度为用户提供直观的链上数据呈现,便于用户更好的洞悉链上业务运行全貌。

总结

趣链自研浏览器组件通过上述模式实现无差异化的调用逻辑,达到对不同区块链底层数据的统一支持,并充分预留了新区块链底层的灵活扩展性。通过上述核心功能模块设计,基本实现了区块链浏览器的最小化产品MVP。

当然,实际在搭建区块链浏览器时,还有很多挑战,最典型的挑战之一就是如何应对大数据量,相信细心的读者已经看到前面的架构介绍中提到了数据公共处理层,这一模块主要就是进行数据存储相关的优化,保证数据存储不会随时间的增加而不断增加,充分减轻服务器存储部分的压力,我们将在后续推文中着重介绍~

来源:金色财经

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

[0:15ms0-13:821ms