一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

提供区块链服务的方法和装置与流程

2022-05-26 22:37:38 来源:中国专利 TAG:


1.本说明书实施例属于区块链技术领域,尤其涉及提供区块链服务的方法和装置。


背景技术:

2.区块链(blockchain)是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链系统中按照时间顺序将数据区块以顺序相连的方式组合成链式数据结构,并以密码学方式保证的不可篡改和不可伪造的分布式账本。由于区块链具有去中心化、信息不可篡改、自治性等特性,区块链也受到人们越来越多的重视和应用。
3.随着区块链的蓬勃发展,越来越多区块链被开发出来,区块链的开发带来区块链算力的瓶颈,而边缘算力的补充为区块链提供了新的算力增长空间。基于此,如何快速搭建提供边缘算力的服务节点,具有重要的现实意义和价值。


技术实现要素:

4.本说明书的实施例描述了一种提供区块链服务的方法和装置,应用于链下设备,从区块链节点获取链上数据的数据结构,并对该数据结构进行解析,生成并存储各个字段的字段表,根据该字段表提供对区块链的数据交互服务。由此,通过将数据结构自动映射到链下设备的字段表,可以使链下设备提供针对区块链的边缘算力。
5.根据第一方面,提供了一种提供区块链服务的方法,应用于链下设备,包括:从区块链节点获取链上数据的数据结构,上述数据结构对上述链上数据中的多个字段进行定义;对获取的上述数据结构进行解析,生成并存储各个字段的字段表,上述字段表中包括对应字段的字段标识和该字段的属性信息;根据上述字段表提供对上述区块链的数据交互服务。
6.在一个实施例中,上述字段的属性信息中包括该字段的字段数据的索引标识,上述方法还包括:从区块链节点接收第一数据,上述第一数据包括各个字段的字段标识和各个字段的与字段标识关联的字段数据;根据各个字段的字段标识获取各个字段的字段表;存储上述第一数据,通过各个字段表中各个字段数据的索引标识建立上述第一数据的各个字段标识与各个字段数据的索引关系;上述根据上述字段表提供对上述区块链的数据交互服务包括:基于上述索引关系查询上述第一数据。
7.在一个实施例中,上述第一数据中还包括数据标识,上述方法还包括:生成并存储上述数据结构的数据结构表,上述数据结构表中包括上述数据结构的名称、数据结构的索引标识和数据结构代码;其中,上述字段表中还包括上述数据结构的索引标识;上述存储上述第一数据,通过上述索引标识建立上述第一数据的各个字段标识与各个字段数据的索引关系包括:确定上述第一数据对应的上述数据结构表,从上述数据结构表中确定上述数据结构的索引标识;根据各个字段的字段标识和上述数据结构的索引标识从上述字段表中确定各个字段数据的索引标识;生成并存储上述第一数据的数据表,上述数据表中包括:上述数据标识、上述数据结构的索引标识、各个字段数据及各个字段数据的索引标识。
8.在一个实施例中,上述基于上述索引关系查询上述第一数据包括:从用户终端接收链上数据查询请求,其中,上述数据查询请求包括上述第一数据的数据标识和目标字段的字段标识;根据上述第一数据的数据标识获取上述第一数据的数据表;根据第一数据的数据表中的数据结构的索引标识和上述目标字段的字段标识获取目标字段的字段表;根据上述目标字段的字段表确定上述目标字段所对应的索引标识;根据所确定的索引标识,从上述第一数据的数据表中查找上述目标字段对应的字段数据;向上述用户终端返回上述字段数据。
9.在一个实施例中,上述方法还包括:根据所提供的链上数据查询服务,生成数据查询日志;将上述数据查询日志进行上链。
10.在一个实施例中,上述根据上述字段表提供对上述区块链的数据交互服务包括:从用户终端接收上链请求,其中,上述上链请求中包括待上链数据的各个字段的字段数据;根据上述待上链数据的各个字段的字段表,从上述各个字段的字段表中确定各个字段数据对应的字段标识;根据上述各个字段数据、各个字段数据对应的字段标识进行数据上链。
11.在一个实施例中,上述从区块链节点获取链上数据的数据结构,包括:向区块链节点发送调用合约的交易,上述合约用于限定链上数据的数据结构;从区块链节点接收上述数据结构。
12.在一个实施例中,上述对获取的上述数据结构进行解析,生成并存储各个字段的字段表,包括:对获取的上述数据结构进行校验;响应于确定上述数据结构校验通过,确定上述数据结构所使用的编程语言;根据编程语言对上述数据结构进行解析,生成各个字段的字段表。
13.根据第二方面,提供了一种提供区块链服务的装置,设置于链下设备,包括:获取单元,配置为从区块链节点获取链上数据的数据结构,上述数据结构对上述链上数据中的多个字段进行定义;解析单元,配置为对获取的上述数据结构进行解析,生成并存储各个字段的字段表,上述字段表中包括对应字段的字段标识和该字段的属性信息;服务单元,配置为根据上述字段表提供对上述区块链的数据交互服务。
14.根据第三方面,提供了一种计算机可读存储介质,其上存储有计算机程序,当上述计算机程序在计算机中执行时,令计算机执行如第一方面中任一实现方式描述的方法。
15.根据第四方面,提供了一种计算设备,包括存储器和处理器,其特征在于,上述存储器中存储有可执行代码,上述处理器执行上述可执行代码时,实现如第一方面中任一实现方式描述的方法。
16.根据本说明书实施例提供的提供区块链服务的方法和装置,应用于链下设备,首先从区块链节点获取链上数据的数据结构,其中,数据结构对链上数据中的多个字段进行定义。然后,对获取的数据结构进行解析,生成并存储各字段的字段表,字段表中包括对应字段的字段标识和该字段的属性信息。最后,根据字段表提供对区块链的数据交互服务。由此,通过将区块链的数据结构自动映射到链下设备的字段表,可以使链下设备提供针对区块链的边缘算力,实现了针对区块链的、用于提供边缘算力的服务节点的快速搭建。
附图说明
17.为了更清楚地说明本说明书实施例的技术方案,下面将对实施例描述中所需要使
用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本说明书中记载的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
18.图1示出一实施例中的区块链架构图;
19.图2示出了本说明书实施例可以应用于其中的一个应用场景的示意图;
20.图3示出了根据一个实施例的提供区块链服务的方法的流程示意图;
21.图4示出了一实施例中的数据结构的示意图;
22.图5示出了本说明书一实施例中在链下设备中存储的表格示意图;
23.图6示出了图5中各个表格的一个实例示意图;
24.图7示出了根据一个实施例的提供区块链服务的装置的示意性框图。
具体实施方式
25.为了使本技术领域的人员更好地理解本说明书中的技术方案,下面将结合本说明书实施例中的附图,对本说明书实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本说明书一部分实施例,而不是全部的实施例。基于本说明书中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本说明书保护的范围。
26.图1示出一实施例中的区块链架构图。如图1所示,区块链100中例如包含6个节点。节点之间的连线示意性的表示p2p(peer to peer,点对点)连接。这些节点上可存储全量的账本,即存储全部区块和全部账户的状态。其中,区块链中的每个节点可通过执行相同的交易而产生区块链中的相同的状态,区块链中的每个节点可存储相同的状态数据库。可以理解,图1中虽然示出了区块链中包括6个节点,本说明书实施例不限于此,而是可以包括其他数目的节点。具体是,区块链中包含的节点可以满足拜占庭容错(byzantine fault tolerance,bft)要求。所述的拜占庭容错要求可以理解为在区块链内部可以存在拜占庭节点,而区块链对外不体现拜占庭行为。一般的,一些拜占庭容错算法中要求节点个数大于3f 1,f为拜占庭节点个数,例如实用拜占庭容错算法pbft(practical byzantine fault tolerance)。
27.区块链领域中的交易可以指在区块链中执行并记录在区块链中的任务单元。交易中通常包括发送字段(from)、接收字段(to)和数据字段(data)。其中,在交易为转账交易的情况中,from字段表示发起该交易(即发起对另一个账户的转账任务)的账户地址,to字段表示接收该交易(即接收转账)的账户地址,data字段中包括转账金额。在交易调用区块链中的智能合约的情况中,from字段表示发起该交易的账户地址,to字段表示交易所调用的合约的账户地址,data字段中包括调用合约中的函数名、及对该函数的传入参数等数据,以用于在交易执行时从区块链中获取该函数的代码并执行该函数的代码。
28.区块链中可提供智能合约的功能。区块链上的智能合约是在区块链系统上可以被交易触发执行的合约。智能合约可以通过代码的形式定义。在以太坊中调用智能合约,是发起一笔指向智能合约地址的交易,使得以太坊网络中每个节点分布式地运行智能合约代码。需要说明的是,除了可以由用户创建智能合约,也可以在创世块中由系统设置智能合约。这类合约一般称为创世合约。一般的,创世合约中可以设置一些区块链的数据结构、参
数、属性和方法。此外,具有系统管理员权限的账户可以创建系统级的合约,或者修改系统级的合约(简称为系统合约)。其中,所述系统合约可用于在区块链中增加不同业务的数据的数据结构。
29.在部署合约的场景中,例如,bob将一个包含创建智能合约信息(即部署合约)的交易发送到如图1所示的区块链中,该交易的data字段包括待创建的合约的代码(如字节码或者机器码),交易的to字段为空,以表示该交易用于部署合约。节点间通过共识机制达成一致后,确定合约的合约地址“0x6f8ae93
…”
,各个节点在状态数据库中添加与该智能合约的合约地址对应的合约账户,分配与该合约账户对应的状态存储,并将合约代码保存在该合约的状态存储中,从而合约创建成功。
30.在调用合约的场景中,例如,bob将一个用于调用智能合约的交易发送到如图1所示的区块链中,该交易的from字段是交易发起方(即bob)的账户的地址,to字段中的“0x6f8ae93
…”
代表了被调用的智能合约的地址,交易的data字段包括调用智能合约的方法和参数。在区块链中对该交易进行共识之后,区块链中的各个节点可分别执行该交易,从而分别执行该合约,基于该合约的执行更新状态数据库。
31.如前所述,区块链的开发带来了区块链算力的瓶颈,而边缘算力的补充为区块链提供了新的算力增长空间。边缘计算,是指在靠近物或数据源头的一侧,采用网络、计算、存储、应用核心能力为一体的开放平台,就近提供最近端服务。其在边缘侧发起,产生更快的网络服务响应,满足行业在实时业务、应用智能、安全与隐私保护等方面的基本需求。边缘计算处于物理实体和工业连接之间,或处于物理实体的顶端。现阶段,有些区块链上的区块链节点依赖边缘算力服务器,边缘算力中最常需要的服务能力包括:链上数据查询服务、上链服务等等。在一些传统方式中,为了开发区块链的边缘算力,针对不同的区块链需要进行多次编码。例如,需要开发区块链合约,包括定义链上数据结构和合约代码,得到serverless(serverless computing,无服务器运算)链上交互接口。同时,需要定义边缘算力服务器上的数据结构,以及定义处理能力的服务接口等等,上述整个过程费事费力。
32.为此,本说明书的实施例提供了一种提供区块链服务的方案,该方案可以应用于链下设备,可以针对不同行业的区块链提供区块链服务。以物流金融链、etc(ethereum classic,以太经典)链、法链、数字商品链等多个区块链201为例,图2示出了本说明书实施例可以应用于其中的一个应用场景的示意图,在图2所示的应用场景中链下设备202为边缘算力服务器。如图2所示,对于上述多个区块链中的每一个区块链201,链下设备202可以从该区块链的任意一个区块链节点获取链上数据的数据结构,其中,数据结构用于对链上数据中的多个字段进行定义。之后,可以对获取的数据结构进行解析,生成并存储各个字段的字段表,这里,字段表中可以包括对应字段的字段标识(例如,字段名称)和该字段的属性信息等。然后,链下设备可以根据字段表提供对该区块链的数据交互服务。实践中,可以将上述多个区块链对应的字段表存储在同一个表中,由此,可以根据该表提供对多个区块链的数据交互服务。
33.继续参见图3,图3示出了根据一个实施例的提供区块链服务的方法的流程示意图。可以理解,该方法可以应用于图2中的链下设备202,该链下设备202可以是任何具有计算、处理能力的装置、设备、平台、设备集群等等。如图3所示,该提供区块链服务的方法,可以包括以下步骤:
34.步骤301,从区块链节点获取链上数据的数据结构。
35.在本实施例中,链下设备可以从区块链的任意一个区块链节点拉取链上数据模型,从而获取链上数据的数据结构。数据结构用于对链上数据中的多个字段进行定义。区块链中存储的数据例如包括交易体、交易收据、区块数据、账户状态数据等多种类型的数据,不同类型的数据可具有不同的数据结构。或者,区块链中可设置多个业务场景,如融资业务场景、佣金业务场景、交易业务场景等,不同的业务场景可设置不同的数据结构,下文中将以该种情况为例进行描述。
36.图4为一实施例中的数据结构的示意图。该数据结构例如为佣金场景下的佣金交易的交易收据的数据结构。如图4所示,该数据结构中定义了字段标识(或字段名称)为categoryid、commissionruleaccountid、senderid、receiverid等的多个字段,另外,该数据结构中还定义了各个字段的其他属性,如字段类型(例如string、uint32、uint64等)、字段代码(code)、以及图4中未示出的一些属性,如是否是唯一键、是否是索引、是否非空、是否复杂类型、关联的数据结构的索引标识等等。
37.如上文所述,在区块链中可通过创世合约或系统合约设置区块链中的数据的数据结构,这些合约的代码中包括数据的数据结构,并提供用于获取该数据结构的函数(或查询接口)。例如,在佣金支付业务场景中,区块链中通过部署佣金合约(如commission合约)来设置如图4所示的佣金数据结构(如commission合约),其中,该佣金合约中包括佣金数据结构,并提供对该佣金数据结构的查询接口。所述佣金数据结构例如用于对佣金业务场景中的各个字段进行定义。另外,该佣金合约可提供其他函数(如支付函数)以用于开展佣金支付业务,例如,用户终端可通过向区块链中发送调用该佣金合约的支付函数的交易,从而向其他用户或者区块链平台支付佣金,区块链节点在执行该交易之后,生成该交易的交易收据并存入区块链中,该交易收据包括在佣金数据结构中定义的多个字段的字段数据。
38.链下设备202可通过向任一区块链节点发送对该查询接口的调用,从而可从区块链节点接收到该数据结构。具体是,对于上述佣金数据结构,链下设备202可向任一区块链节点发送查询请求(或交易),该查询请求中调用佣金合约提供的查询接口,区块链节点在接收到该查询请求之后,执行该查询接口,获取佣金合约的代码中包括的佣金数据结构,并将该佣金数据结构返回给链下设备202。
39.步骤302,对获取的数据结构进行解析,生成并存储各个字段的字段表。
40.在本实施例中,可以对步骤301中获取的数据结构进行解析,生成并存储各个字段的字段表。图5为本说明书一实施例中在链下设备中存储的表格示意图,其中包括字段表501。如图5所示,字段表501可以用于定义数据结构中的单个字段的信息。本例中,上述字段表501中可以包括对应字段的字段标识(例如,字段名称)和该字段的属性信息。其中,字段的属性信息可以包括与字段的属性相关的各种信息,包括但不限于创建时间、更新时间、所属数据结构的索引标识、该字段对应的字段数据的索引标识、字段code(代码)、字段类型、是否是唯一键、是否是索引、是否非空、是否复杂类型、关联的数据结构的索引标识等等。其中,字段数据的索引标识为由链下设备202生成的在数据结构多个字段中唯一标识目标字段的字段数据的名称或编号。通过生成字段数据的索引标识,链下设备202在存储具有该数据结构的数据时,可将各个字段数据的索引标识与对应的字段数据关联的存储,从而可通过索引标识进行对存储数据中的目标字段数据的读取。
41.图6为图5中各个表格的实例示意图。以图4中的佣金数据结构为例,通过解析该数据结构,可得出图6所示的字段表601。例如,字段“categoryid”对应的字段表如字段表601中第2行所示,其中,“字段标识categoryid”、“字段代码categoryid”、“字段类型string”等字段数据可从图4中的数据结构解析获得,“字段数据的索引标识v0”为链下设备202生成的与字段“categoryid”对应的索引标识,“数据结构的索引标识01”为链下设备202生成的与该commission数据结构对应的索引标识。
42.在一些可选的实现方式中,上述步骤302还可以具体如下进行:
43.首先,对获取的数据结构进行校验。举例来说,可以校验数据结构内数据间的语法是否符合语法规则,或者是否存在语法错误。
44.然后,在确定数据结构校验通过后,确定数据结构所使用的编程语言。作为示意,数据结构可以使用的编程语言可以包括但不限于:solidity编程语言、golang编程语言、c 编程语言等等。
45.最后,根据编程语言对数据结构进行解析,生成各个字段的字段表。举例来说,针对不同编程语言,可以预先设定对应的解析方式,由此,可以实现根据编程语言对数据结构进行解析。通过本实现方式,可以实现对不同编程语言的数据结构的解析。
46.步骤303,根据字段表提供对区块链的数据交互服务。
47.在本实施例中,可以根据生成的字段表,提供对区块链的数据交互服务。这里,对区块链的数据交互服务可以包括链上数据查询服务、上链服务等边缘算力中常需要的服务能力。作为示例,链下设备中可以包括sql(structured query language,结构化查询语言)转换引擎、结果转换引擎、权限管控引擎、日志管控引擎等等。其中,sql转换引擎可以将查询接口中的查询参数转换为针对表的查询sql,结果转换引擎可以将基于表得到的查询结果解析成查询接口所需的结果,权限管控引擎可以提供接口鉴权控制,日志管控引擎可以记录查询日志、上链日志等等。
48.在一些可选的实现方式中,上述提供区块链服务的方法还可以包括以下内容:
49.步骤1),实时从区块链节点接收第一数据,其中,第一数据可以包括但不限于数据标识、各个字段的字段标识、各个字段的与字段标识关联的字段数据,该第一数据中包括的字段标识指示了该第一数据所对应的数据结构,或者该第一数据中也可以包括对应的数据结构的名称。其中,该第一数据例如为佣金交易的交易收据。该交易收据例如具有如下所述的形式:
50.{receipt1
51.categoryid:02
52.……
53.senderid:a
54.receiverid:b}
55.其中,“receipt1”为数据标识,交易收据receipt1中包括categoryid、senderid、receiverid等多个字段的字段名称(或字段标识)和字段值。
56.步骤2),根据各个字段的字段标识获取各个字段的字段表。
57.步骤3),存储上述第一数据,并通过各个字段表中各个字段数据的索引标识建立上述第一数据的各个字段标识与各个字段数据的索引关系。具体是,可建立各个字段数据
的索引标识与对应的字段数据的存储位置(或存储地址)的映射关系表,从而可根据字段的字段表确定字段标识对应的字段数据的索引标识,并根据该映射关系表确定字段数据的存储位置,从而读取该字段数据。
58.在如上所述存储第一数据之后,上述步骤303可以具体如下进行:基于上述索引关系查询上述第一数据。
59.可选的,上述提供区块链服务的方法还可以包括以下内容:生成并存储数据结构的数据结构表。
60.作为示例,图5示出的链下设备中存储的表格示意图中还包括数据结构表502。该数据结构表502中可以包括主键id(标识)、数据结构的名称、数据结构的索引标识、数据结构代码、数据结构版本、以及所属区块链的区块链id(标识)和区块链名称等信息。其中,数据结构的索引标识为由链下设备202生成的在多个数据结构中唯一标识目标数据结构的数据结构的名称或编号。通过生成数据结构的索引标识,链下设备202在存储具有该数据结构的数据时,可将各个数据结构的索引标识与对应的数据结构的多个字段的字段数据的索引标识关联的存储,从而可通过索引标识进行对存储数据中的目标数据结构的多个字段的字段数据的读取。
61.举例来说,可以根据预设的解析方式对数据结构进行解析,得到数据结构的数据结构表。图6作为图5中各个表格的实例示意图。以图4中的佣金数据结构为例,通过解析该数据结构,可得出图6所示的数据结构表602。
62.在该实施方式下,上述步骤3),存储上述第一数据,并通过各个字段表中各个字段数据的索引标识建立上述第一数据的各个字段标识与各个字段数据的索引关系,可以具体如下实现:
63.s1,确定第一数据对应的数据结构表,从数据结构表中确定数据结构的索引标识。
64.具体是,根据上述交易收据receipt1中包括的categoryid、senderid、receiverid等多个字段,可以确定交易收据receipt1中包括的多个字段与图4所示的数据结构中定义的多个字段一致,从而确定交易收据receipt1与图6所示的数据结构表602对应。或者,在交易收据receipt1中包括数据结构的名称(commission)或者对应的合约名称的情况下,可根据数据结构的名称确定数据结构表。之后链下设备202可从该数据结构表602中读取交易收据receipt1所具有的数据结构的索引标识“01”。
65.s2,根据各个字段的字段标识和数据结构的索引标识从字段表中确定各个字段数据的索引标识。
66.具体是,如图6所示,以佣金交易的交易收据为例,首先根据数据结构的索引标识01和各个字段的字段标识确定各个字段的字段表601,然后可以从字段表601中确定各个字段的字段数据的索引标识。例如,根据字段标识categoryid,可从字段表601中确定字段categoryid的字段数据的索引标识为v0。
67.s3,生成并存储第一数据的数据表,其中,数据表中可以包括数据标识、数据结构的索引标识、各个字段数据、以及各个字段数据的索引标识。作为示例,图5示出的链下设备中存储的表格示意图中还包括数据表503。以及图6作为图5中各个表格的实例示意图。以图4中的佣金数据结构为例,通过实时拉取链上数据,可得出图6所示的数据表603。其中,vo数据、v1数据等为与字段数据的索引标识关联的字段数据,通过将数据结构的多个字段的字
段数据分字段存储有利于实现分字段读取数据。数据的索引标识可以是由链下设备202生成的用于标识该数据的名称或编号,链下设备202可将该数据的索引标识与该数据的存储地址信息关联地存储,从而可通过该数据的索引标识读取到该数据。
68.在一些可选的实现方式中,上述数据交互服务可以是链上数据查询服务,以及上述基于索引关系查询第一数据,可以具体如下进行:
69.1)从用户终端接收链上数据查询请求。其中,数据查询请求可以包括第一数据的数据标识、目标字段的字段标识等等。
70.例如,该数据查询请求用于查询交易收据receipt1中的categoryid字段的字段数据,该数据查询请求可包括目标数据的数据标识“receipt1”和目标数据的字段标识“categoryid”。
71.在进行链上数据查询时,可以根据字段顺序将链上数据查询请求解析并拼装成sql,根据拼装的sql找到数据表中的数据。
72.2)根据第一数据的数据标识获取第一数据的数据表。
73.具体是,链下设备202可根据数据标识“receipt1”可以获取第一数据的数据表603。
74.3)根据第一数据的数据表中的数据结构的索引标识和目标字段的字段标识获取目标字段的字段表。
75.具体是,链下设备202可根据第一数据的数据表中的数据结构的索引标识01确定字段表601,并根据字段标识categoryid确定字段表601中的categoryid字段的字段表。
76.4)根据目标字段的字段表确定目标字段所对应的索引标识。
77.具体是,链下设备202可根据categoryid字段的字段表确定categoryid字段所对应的索引标识(“v0”)。
78.5)根据所确定的索引标识,从第一数据的数据表中查找目标字段对应的字段数据。
79.具体是,链下设备202可根据索引标识v0从第一数据的数据表中查找categoryid字段对应的字段数据,并将该字段数据作进一步处理后反馈。
80.6)向用户终端返回查找到的字段数据。
81.可以理解,上文中仅以一个实例的方式描述了本说明书实施例提供的数据查询服务,本说明书实施例提供的数据查询服务不限于此。例如,在另一个实例中,查询请求中可包括待查询数据包括的字段标识和字段数据(例如senderid:alice),该查询请求例如用于查询由alice发送的全部交易。链下设备202在接收到该查询请求之后,可根据senderid定位到commission数据结构中senderid字段对应的字段表,从字段表中获取senderid字段的索引标识(例如v5),根据该索引标识检索全部v5=alice的数据表,并从检索到的数据表中获取由alice发送的交易,链下设备202还可以类似地检索到其他数据结构的由alice发送的交易。
82.通过本实现方式,实现了基于边缘算力的链上数据查询服务。
83.在一些可选的实现方式中,上述提供区块链服务的方法还可以包括以下内容:根据所提供的链上数据查询服务,生成数据查询日志;将数据查询日志进行上链。
84.此外,作为边缘算力提供设备的链下设备所能提供的服务可以封装成接口的形
式。链下设备还可以具有权限管控能力,用于对调用接口的用户进行鉴权。
85.在一些可选的实现方式中,上述数据交互服务还可以是上链服务,以及上述步骤303可以具体如下进行:
86.首先,从用户终端接收上链请求。这里,上链请求中可以包括待上链数据的各个字段的字段数据。该上链请求例如用于将调用佣金合约(commission合约)的交易上链,同样的,该交易也符合commission数据结构。其中,该上链请求中例如包括senderid字段(对应于交易的from字段)、recieverid字段(对应于交易的to字段)和data字段各自的字段数据,例如,senderid字段的数据为“alice”,receiverid字段数据为commission合约的合约地址,data字段的数据包括commission合约中的支付函数名,以表示该交易由账户alice发起,并调用commission合约中的支付函数。
87.然后,根据待上链数据的各个字段的字段表,从各个字段的字段表中确定各个字段数据对应的字段标识。
88.具体是,可以根据各个字段的字段数据,确定待上链数据的数据结构表,从数据结构表确定待上链数据的数据结构的索引标识。例如,链下设备202可根据上链数据中的to字段的字段数据中的commission合约的合约地址,确定待上链数据的数据结构表为图6所示的数据结构表602,从而可从该数据结构表602中读取数据结构的索引标识01。之后,根据数据结构的索引标识01获取各个字段的字段表601,从各个字段的字段表中确定各个字段数据对应的字段标识。
89.最后,根据各个字段数据、各个字段数据对应的字段标识,进行数据上链。
90.具体是,可根据各个字段数据对应的字段标识和各个字段数据生成上链交易,例如,将senderid字段的字段数据置于交易的from字段处,将receiverid字段的字段数据置于交易的to字段处等,从而生成符合预设交易形式的上链交易,并将该上链交易发送给区块链的节点,以将该交易存入区块链中。通过本实现方式,可以实现基于边缘算力的上链服务。
91.回顾以上过程,在本说明书的实施例中,将区块链的链上数据的数据结构自动映射为链下设备的表,链下设备基于映射得到的表可以提供边缘算力。由此,可以快速为区块链搭建可以提供边缘算力的服务节点。
92.根据另一方面的实施例,提供了一种提供区块链服务的装置。上述提供区块链服务的装置,设置于链下设备,链下设备可以是任何具有计算、处理能力的设备、平台或设备集群。
93.图7示出了根据一个实施例的提供区块链服务的装置的示意性框图。如图7所示,该提供区块链服务的装置700包括:获取单元701,配置为从区块链节点获取链上数据的数据结构,上述数据结构对上述链上数据中的多个字段进行定义;解析单元702,配置为对获取的上述数据结构进行解析,生成并存储各个字段的字段表,上述字段表中包括对应字段的字段标识和该字段的属性信息;服务单元703,配置为根据上述字段表提供对上述区块链的数据交互服务。
94.在本实施例的一些可选的实现方式中,字段的属性信息中包括该字段的字段数据的索引标识,上述装置700还包括:接收单元(图中未示出),配置为从区块链节点接收第一数据,上述第一数据包括各个字段的字段标识和各个字段的与字段标识关联的字段数据;
字段表获取单元(图中未示出),配置为根据各个字段的字段标识获取各个字段的字段表;存储单元(图中未示出),配置为存储上述第一数据,通过各个字段表中各个字段数据的索引标识建立上述第一数据的各个字段标识与各个字段数据的索引关系;上述服务单元703包括查询模块(图中未示出),上述查询模块配置为:基于上述索引关系查询上述第一数据。
95.在本实施例的一些可选的实现方式中,上述第一数据中还包括数据标识,上述装置700还包括:生成单元(图中未示出),配置为生成并存储上述数据结构的数据结构表,上述数据结构表中包括上述数据结构的名称、数据结构的索引标识和数据结构代码;其中,上述字段表中还包括上述数据结构的索引标识;上述存储单元进一步配置为:确定上述第一数据对应的上述数据结构表,从上述数据结构表中确定上述数据结构的索引标识;根据各个字段的字段标识和上述数据结构的索引标识从上述字段表中确定各个字段数据的索引标识;生成并存储上述第一数据的数据表,上述数据表中包括:上述数据标识、上述数据结构的索引标识、各个字段数据及各个字段数据的索引标识。
96.在本实施例的一些可选的实现方式中,上述上述查询模块进一步配置为:从用户终端接收链上数据查询请求,其中,上述数据查询请求包括上述第一数据的数据标识和目标字段的字段标识;根据上述第一数据的数据标识获取上述第一数据的数据表;根据第一数据的数据表中的数据结构的索引标识和上述目标字段的字段标识获取目标字段的字段表;根据上述目标字段的字段表确定上述目标字段所对应的索引标识;根据所确定的索引标识,从上述第一数据的数据表中查找上述目标字段对应的字段数据;向上述用户终端返回上述字段数据。
97.在本实施例的一些可选的实现方式中,上述装置700还包括:日志生成单元(图中未示出),配置为根据所提供的链上数据查询服务,生成数据查询日志;上链单元(图中未示出),配置为将上述数据查询日志进行上链。
98.在本实施例的一些可选的实现方式中,上述服务单元703进一步配置为:从用户终端接收上链请求,其中,上述上链请求中包括待上链数据的各个字段的字段数据;根据上述待上链数据的各个字段的字段表,从上述各个字段的字段表中确定各个字段数据对应的字段标识;根据上述各个字段数据、各个字段数据对应的字段标识进行数据上链。
99.在本实施例的一些可选的实现方式中,上述获取单元701进一步配置为:向区块链节点发送调用合约的交易,上述合约用于限定链上数据的数据结构;从区块链节点接收上述数据结构。
100.在本实施例的一些可选的实现方式中,上述解析单元702进一步配置为:对获取的上述数据结构进行校验;响应于确定上述数据结构校验通过,确定上述数据结构所使用的编程语言;根据编程语言对上述数据结构进行解析,生成各个字段的字段表。
101.根据另一方面的实施例,还提供一种计算机可读存储介质,其上存储有计算机程序,当上述计算机程序在计算机中执行时,令计算机执行图3所描述的方法。
102.根据再一方面的实施例,还提供一种计算设备,包括存储器和处理器,其特征在于,上述存储器中存储有可执行代码,上述处理器执行上述可执行代码时,实现图3所描述的方法。
103.在20世纪90年代,对于一个技术的改进可以很明显地区分是硬件上的改进(例如,对二极管、晶体管、开关等电路结构的改进)还是软件上的改进(对于方法流程的改进)。然
而,随着技术的发展,当今的很多方法流程的改进已经可以视为硬件电路结构的直接改进。设计人员几乎都通过将改进的方法流程编程到硬件电路中来得到相应的硬件电路结构。因此,不能说一个方法流程的改进就不能用硬件实体模块来实现。例如,可编程逻辑器件(programmable logic device,pld)(例如现场可编程门阵列(field programmable gate array,fpga))就是这样一种集成电路,其逻辑功能由用户对器件编程来确定。由设计人员自行编程来把一个数字系统“集成”在一片pld上,而不需要请芯片制造厂商来设计和制作专用的集成电路芯片。而且,如今,取代手工地制作集成电路芯片,这种编程也多半改用“逻辑编译器(logic compiler)”软件来实现,它与程序开发撰写时所用的软件编译器相类似,而要编译之前的原始代码也得用特定的编程语言来撰写,此称之为硬件描述语言(hardware description language,hdl),而hdl也并非仅有一种,而是有许多种,如abel(advanced boolean expression language)、ahdl(altera hardware description language)、confluence、cupl(cornell university programming language)、hdcal、jhdl(java hardware description language)、lava、lola、myhdl、palasm、rhdl(ruby hardware description language)等,目前最普遍使用的是vhdl(very-high-speed integrated circuit hardware description language)与verilog。本领域技术人员也应该清楚,只需要将方法流程用上述几种硬件描述语言稍作逻辑编程并编程到集成电路中,就可以很容易得到实现该逻辑方法流程的硬件电路。
104.控制器可以按任何适当的方式实现,例如,控制器可以采取例如微处理器或处理器以及存储可由该(微)处理器执行的计算机可读程序代码(例如软件或固件)的计算机可读介质、逻辑门、开关、专用集成电路(application specific integrated circuit,asic)、可编程逻辑控制器和嵌入微控制器的形式,控制器的例子包括但不限于以下微控制器:arc 625d、atmel at91sam、microchip pic18f26k20以及silicone labs c8051f320,存储器控制器还可以被实现为存储器的控制逻辑的一部分。本领域技术人员也知道,除了以纯计算机可读程序代码方式实现控制器以外,完全可以通过将方法步骤进行逻辑编程来使得控制器以逻辑门、开关、专用集成电路、可编程逻辑控制器和嵌入微控制器等的形式来实现相同功能。因此这种控制器可以被认为是一种硬件部件,而对其内包括的用于实现各种功能的装置也可以视为硬件部件内的结构。或者甚至,可以将用于实现各种功能的装置视为既可以是实现方法的软件模块又可以是硬件部件内的结构。
105.上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为服务器系统。当然,本技术不排除随着未来计算机技术的发展,实现上述实施例功能的计算机例如可以为个人计算机、膝上型计算机、车载人机交互设备、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任何设备的组合。
106.虽然本说明书一个或多个实施例提供了如实施例或流程图所述的方法操作步骤,但基于常规或者无创造性的手段可以包括更多或者更少的操作步骤。实施例中列举的步骤顺序仅仅为众多步骤执行顺序中的一种方式,不代表唯一的执行顺序。在实际中的装置或终端产品执行时,可以按照实施例或者附图所示的方法顺序执行或者并行执行(例如并行处理器或者多线程处理的环境,甚至为分布式数据处理环境)。术语“包括”、“包含”或者其
任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、产品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、产品或者设备所固有的要素。在没有更多限制的情况下,并不排除在包括所述要素的过程、方法、产品或者设备中还存在另外的相同或等同要素。例如若使用到第一,第二等词语用来表示名称,而并不表示任何特定的顺序。
107.为了描述的方便,描述以上装置时以功能分为各种模块分别描述。当然,在实施本说明书一个或多个时可以把各模块的功能在同一个或多个软件和/或硬件中实现,也可以将实现同一功能的模块由多个子模块或子单元的组合实现等。以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
108.本发明是参照根据本发明实施例的方法、装置(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
109.这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
110.这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
111.在一个典型的配置中,计算设备包括一个或多个处理器(cpu)、输入/输出接口、网络接口和内存。
112.内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(ram)和/或非易失性内存等形式,如只读存储器(rom)或闪存(flash ram)。内存是计算机可读介质的示例。
113.计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(pram)、静态随机存取存储器(sram)、动态随机存取存储器(dram)、其他类型的随机存取存储器(ram)、只读存储器(rom)、电可擦除可编程只读存储器(eeprom)、快闪记忆体或其他内存技术、只读光盘只读存储器(cd-rom)、数字多功能光盘(dvd)或其他光学存储、磁盒式磁带,磁带磁磁盘存储、石墨烯存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据
信号和载波。
114.本领域技术人员应明白,本说明书一个或多个实施例可提供为方法、系统或计算机程序产品。因此,本说明书一个或多个实施例可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本说明书一个或多个实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产品的形式。
115.本说明书一个或多个实施例可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本本说明书一个或多个实施例,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
116.本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。在本说明书的描述中,参考术语“一个实施例”、“一些实施例”、“示例”、“具体示例”、或“一些示例”等的描述意指结合该实施例或示例描述的具体特征、结构、材料或者特点包含于本说明书的至少一个实施例或示例中。在本说明书中,对上述术语的示意性表述不必须针对的是相同的实施例或示例。而且,描述的具体特征、结构、材料或者特点可以在任一个或多个实施例或示例中以合适的方式结合。此外,在不相互矛盾的情况下,本领域的技术人员可以将本说明书中描述的不同实施例或示例以及不同实施例或示例的特征进行结合和组合。
117.以上所述仅为本说明书一个或多个实施例的实施例而已,并不用于限制本本说明书一个或多个实施例。对于本领域技术人员来说,本说明书一个或多个实施例可以有各种更改和变化。凡在本说明书的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在权利要求范围之内。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献