[发明专利]一种数据一致性处理方法、装置、终端及存储介质在审
申请号: | 202210733917.7 | 申请日: | 2022-06-27 |
公开(公告)号: | CN115098521A | 公开(公告)日: | 2022-09-23 |
发明(设计)人: | 谭锦志;张延楠;施德强;尚璇;胡麦芳 | 申请(专利权)人: | 杭州趣链科技有限公司 |
主分类号: | G06F16/23 | 分类号: | G06F16/23;G06F16/2458;G06F16/27 |
代理公司: | 深圳中一联合知识产权代理有限公司 44414 | 代理人: | 张禹 |
地址: | 310000 浙江省杭州市*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 数据一致性 处理 方法 装置 终端 存储 介质 | ||
本申请适用于区块链技术领域,提供一种数据一致性处理方法、装置、终端及存储介质,其中方法包括:获取业务数据上链请求,在检测到将所述待上链业务数据写入至所述区块链出现异常时,从系统数据库中提取标志位为第一值的目标数据上链请求记录;从所述区块链中查找与所述目标数据上链请求记录匹配的目标数据;基于所述目标数据,在确定所述系统数据库中所述业务数据与所述区块链中的上链数据具备一致性时,将所述目标数据上链请求记录对应的所述标志位置为第二值。该方案能够减少业务方和区块链服务器的服务压力,同时确保数据同步的及时性。
技术领域
本申请属于区块链技术领域,尤其涉及一种数据一致性处理方法、装置、终端及存储介质。
背景技术
在区块链业务中,数据上链需要调用合约第三方服务来实现。在业务方调用区块链智能合约时,如果遇到服务重启或者网络拥堵导致不能够及时获取链上合约执行的完成状态,导致业务方的数据和区块链的数据一致无法保证。
现有的处理手段是进行数据的全量拉取,即每间隔一定时长,通过合约提供的接口对账本数据与业务数据全量比对更新,确保业务方的数据与区块链的数据保持一致性,上述过程会随着数据量的增加造成数据处理性能降低,且需要定时拉取全量数据,会增加业务方和区块链服务的服务器压力,且受网络波动性影响较大。
现有处理手段也有在用户需要数据查询时再触发数据的主动拉取,即当用户查询数据或操作数据时先去区块链上获取账本数据,使业务方数据能够与区块链的数据保持一致性。但该方法在保持数据一致性上具有一定的滞后性,给用户数据操作带来不便。
发明内容
本申请实施例提供了一种数据一致性处理方法、装置、终端及存储介质,以解决在保持数据一致性时,现有技术会增加业务方和区块链服务的服务器压力及数据同步具有滞后性的问题。
本申请实施例的第一方面提供了一种数据一致性处理方法,包括:
获取业务数据上链请求,所述业务数据上链请求用于指示将待上链业务数据写入至区块链;
在检测到将所述待上链业务数据写入至所述区块链出现异常时,从系统数据库中提取标志位为第一值的目标数据上链请求记录;所述系统数据库中存储有业务数据、与所述业务数据上链请求对应的数据上链请求记录及用于指示所述业务数据上链请求的处理状态的标志位;
从所述区块链中查找与所述目标数据上链请求记录匹配的目标数据;
基于所述目标数据,在确定所述系统数据库中所述业务数据与所述区块链中的上链数据具备一致性时,将所述目标数据上链请求记录对应的所述标志位置为第二值。
本申请实施例的第二方面提供了一种数据一致性处理装置,包括:
获取模块,用于获取业务数据上链请求,所述业务数据上链请求用于指示将待上链业务数据写入至区块链;
提取模块,用于在检测到将所述待上链业务数据写入至所述区块链出现异常时,从系统数据库中提取标志位为第一值的目标数据上链请求记录;所述系统数据库中存储有业务数据、与所述业务数据上链请求对应的数据上链请求记录及用于指示所述业务数据上链请求的处理状态的标志位;
查找模块,用于从所述区块链中查找与所述目标数据上链请求记录匹配的目标数据;
状态值设置模块,用于基于所述目标数据,在确定所述系统数据库中所述业务数据与所述区块链中的上链数据具备一致性时,将所述目标数据上链请求记录对应的所述标志位置为第二值。
本申请实施例的第三方面提供了一种终端,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如第一方面所述方法的步骤。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州趣链科技有限公司,未经杭州趣链科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210733917.7/2.html,转载请声明来源钻瓜专利网。