[发明专利]分布式软件程序数据一致性的判断方法及系统有效
申请号: | 201810362576.0 | 申请日: | 2018-04-20 |
公开(公告)号: | CN108710557B | 公开(公告)日: | 2021-10-19 |
发明(设计)人: | 刘太强;邱凤雷;陈长贵;卓文博;刘超 | 申请(专利权)人: | 烽火通信科技股份有限公司 |
主分类号: | G06F11/30 | 分类号: | G06F11/30;G06F11/34 |
代理公司: | 武汉智权专利代理事务所(特殊普通合伙) 42225 | 代理人: | 沈林华 |
地址: | 430000 湖北省武*** | 国省代码: | 湖北;42 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 分布式 软件 程序 数据一致性 判断 方法 系统 | ||
本发明公开了一种分布式软件程序数据一致性的判断方法及系统,涉及软件程序领域。该方法包括以下步骤:对从外部获取的数据进行编号,分布式软件程序处理数据时,将所有与该数据相关联的修改后的数据都与该数据的编号关联,并确定处理该数据的起点程序、中间点程序和终点程序;通过核实某一编号相关联的数据从起点程序、中间点程序到终点程序的处理链条是否完整,判断各分布式软件程序间数据的关联性和完整性。本发明不需要各程序间相互的计算,就能很快确定程序间数据的一致性及差异在哪里。
技术领域
本发明涉及软件程序领域,具体是涉及一种分布式软件程序数据一致性的判断方法及系统。
背景技术
当前的程序越来越复杂,多线程、分布式的程序已是很常见的,那么各部分的数据需要做一致性判断,即判断数据是否相同,因为数据在传递时会有一些因素导致丢失,例如:网络突然断开,导致收发两端数据不一致,将是很大的困难,因为假设分布式程序由N个程序组成,N1,N为正整数,如果N个程序都在处理业务,并且每个程序都在处理不同的业务,有M个程序突然坏掉了,MN,M为正整数,然后这些坏掉的程序又借助备份数据恢复了运转,此时如何判断影响了哪些业务数据,即N个程序间哪部分的数据依然是一致的,或如何判断哪些业务数据受损了,哪些是完整的。
当软件程序是多线程或分布式的时候,判断分布式程序间的数据一致性状况是比较困难的,如何简单判断程序数据的受损程度是一个很重要方面,必须先知道哪些数据受损了,才能有效的采取应对措施。
目前有些软件方案是将各业务间的数据相互进行核对,以判断哪些数据丢失了,哪些数据是完整的,在程序比较多的时候,这样比较起来是非常复杂的,例如:如果N个程序相互之间都有业务交互,那么数据的计算量将是N(N-1)的量级,这样即便计算出受损的业务数据,计算量也是很大的。
发明内容
本发明的目的是为了克服上述背景技术的不足,提供一种分布式软件程序数据一致性的判断方法及系统,不需要各程序间相互的计算,就能很快确定程序间数据的一致性及差异在哪里。
本发明提供一种分布式软件程序数据一致性的判断方法,包括以下步骤:
S1、对从外部获取的数据进行编号,分布式软件程序处理数据时,将所有与该数据相关联的修改后的数据都与该数据的编号关联,并确定处理该数据的起点程序、中间点程序和终点程序;
S2、通过核实某一编号相关联的数据从起点程序、中间点程序到终点程序的处理链条是否完整,判断各分布式软件程序间数据的关联性和完整性;
步骤S1具体包括以下步骤:
分布式软件程序处理从外部获取的数据时,对该数据进行编号;所有程序往其他业务传递与该数据相关联的修改后的数据时,均携带该数据的编号,将该程序标记为该数据的起点程序;
其余程序收到所述起点程序发来的与该数据相关联的修改后的数据时,沿用该数据的编号;其余程序处理完该数据相关联的修改后的数据,若继续往其他程序传递与该数据相关联的数据,则将该程序标记为该数据的中间点程序;若不再往其他程序传递与该数据相关联的数据,则将该程序标记为该数据的终点程序。
在上述技术方案的基础上,步骤S1中,对从外部获取的数据进行编号时,编号在系统内的起点程序间不互相重复,而且递增。
在上述技术方案的基础上,步骤S1中,对从外部获取的数据进行编号时,只有直接收到外部数据时,才用新编号。
在上述技术方案的基础上,步骤S2具体包括以下步骤:
若某一编号相关联的数据在系统里的处理链条中有对应的起点程序、所有的中间点程序及终点程序,则认为某一编号相关联的数据处理已经完整地结束,其数据是完整的,否则认为数据不完整。
本发明还提供一种分布式软件程序数据一致性的判断系统,包括关联标记单元、数据完整性判断单元,其中:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于烽火通信科技股份有限公司,未经烽火通信科技股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810362576.0/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种对工件进行检测的装置
- 下一篇:用于计算机的运行控制方法及装置