CN104079663A - 分布式实时同步网络系统及其通告数据的方法 - Google Patents
分布式实时同步网络系统及其通告数据的方法 Download PDFInfo
- Publication number
- CN104079663A CN104079663A CN201410334955.0A CN201410334955A CN104079663A CN 104079663 A CN104079663 A CN 104079663A CN 201410334955 A CN201410334955 A CN 201410334955A CN 104079663 A CN104079663 A CN 104079663A
- Authority
- CN
- China
- Prior art keywords
- server
- priority
- highest
- servers
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Landscapes
- Computer And Data Communications (AREA)
Abstract
本发明公开一种结构简单、能使系统内各服务器拥有相同数据并实时同步的分布式实时同步网络系统及其通告数据的方法。该系统内的所有服务器所存数据相同且对每一个服务器赋予不同的优先级,其中,1)每台服务器均定时通报本服务器的优先级并在收到邻居服务器的优先级通告之后,向除该优先级通告发出服务器之外的其他邻居服务器转发该通告;2)优先级低的服务器将其用户终端提出的请求信息传递给优先级最高的服务器,或者通过相邻服务器依次直到转发给优先级最高的服务器;3)请求信息经所述优先级最高的服务器备案后,将该备案信息经相邻服务器转发至该系统的每台服务器中并使所有服务器保持相同的存储数据。
Description
技术领域
本发明涉及一种基于互联网的分布式系统,特别涉及一种分布式实时同步网络系统及其通告数据的方法。
背景技术
随着互联网技术的快速发展,其已成为人们生活中必不可少的一种工具,数据的共享系统已成为各种互联网应用中的一个基础功能。在数据的共享系统中,数据不再是独立的分散于各服务器,而是由多台服务器共同维护的统一的数据;任何一台服务器都可以提出修改数据的要求,数据的任何修改,都需要实时反映在系统中的每一台服务器上。在这种运行模式下,如何在不会明显影响用户使用体验的情况下,保证多台服务器数据的实时同步,成了分布式系统绕不开的技术问题。
目前,应用比较广的分布式算法有Paxos和Viewstamps算法。这两个算法都比较复杂;为了解决一致性问题,算法的逻辑比较难懂。具体实现项目有:以Paxos算法为基础的zookeeper项目等等。
对于系统来说,不同的服务器会接收到来自不同的用户的修改数据的请求。每个请求,都是对整个系统的数据进行修改。显然,如果不对这些来自于不同的服务器的请求进行排序,是不能响应这些请求的。只有处理经过排序之后的请求,系统的数据才不至于出现混乱。
在处理完用户的修改请求之后,如何把处理的结果同步到系统中的其他所有的服务器,也是该系统需要解决的问题。
同时,该系统也允许加入新的服务器,新加入的服务器能够及时的获得系统中现有的数据,以便向用户提供服务;该系统也允许当中的服务器离开该系统(比如出现问题,不能继续工作)。在这些情况下,要求整个系统都能持续的为用户提供正常的服务。
而现有技术中的分布式网络系统,存在如下不足:
1)系统内设备复杂,报文程序繁琐。
2)系统中服务器的数量需要事先设定好,当参与到系统中服务器的数量动态变化超过设定值时,该系统则不能正常工作。
发明内容
本发明要解决的技术问题是提供一种结构简单、能使系统内各服务器拥有相同数据并实时同步的分布式实时同步网络系统及其通告数据的方法。
为了解决上述技术问题,本发明采用的技术方案为:
本发明的分布式实时同步网络系统,包括若干台服务器和连接在各服务器上的用户终端,该系统内的所有服务器所存数据相同且对每一个服务器赋予不同的优先级,其中,
1)每台服务器均定时向相邻的服务器通报本服务器的优先级;每台服务器在收到邻居服务器的优先级通告之后,向除该优先级通告发出服务器之外的其他邻居服务器转发该通告;
2)优先级低的服务器将其用户终端提出的请求信息传递给优先级最高的服务器,或者通过相邻服务器依次直到转发给优先级最高的服务器;
3)所述请求信息经所述优先级最高的服务器备案后,将该备案信息经相邻服务器转发至该系统的每台服务器中并使所有服务器保持相同的存储数据。
对新加入该系统的服务器赋予优先级,当赋予其的优先级为最高时,将其服务器中所存的数据转发至其它服务器;当赋予其的优先级低于最高时,该服务器从系统内优先级最高的服务器中获取与己不同的数据。
所述最高优先级的服务器退出该系统后,该系统重新设定优先级最高的服务器。
在每台服务器中设有过滤再次收到的所述备案信息的历史报文信息缓存器。
本发明的分布式实时同步网络系统内通告数据的方法,其按以下步骤执行:
1)该系统中每台服务器启动时,均会获取优先级,同时,其内部会自动产生一个定时器,在服务器收到比自己更高的优先级通告之后,会延迟定时器的触发时间,当该定时器在T时间被触发后,该服务器自动成为该系统中优先级最高的服务器而获得决策权;
2)每台服务器均定时向其它服务器通报本服务器的优先级并随时接收其它服务器优先级通告报文,之后向邻居服务器转发来自其它服务器的优先级通告报文;
3)当一台服务器收到其他服务器的优先级通告后,经与本地优先级比较,若本地优先级为系统中最高,则忽略该报文;若本地优先级较低且不拥有决策权,则重新设置获取决策权的定时器;若本地优先级较低且拥有决策权,则放弃决策权,同时设置定时器;
4)优先级低的服务器将其用户终端提出的请求信息传递给优先级最高的服务器,或者通过相邻服务器依次直到转发给优先级最高的服务器;
5)所述请求信息经所述优先级最高的服务器备案后,将该备案信息经相邻服务器转发至该系统的每台服务器中并使所有服务器保持相同的存储数据。
本发明方法中,优先级通告报文包含以下内容:服务器的唯一标识和每次报文生成的序列号。
本发明方法中,在具有环状路径的网络系统中,在每台服务器中设有过滤再次收到的所述通告报文的历史报文信息缓存器。
本发明方法中,拥有决策权的服务器或用户终端退出该系统,系统中某服务器内部的定时器超时被触发之后,自动成为优先级最高的服务器并获取决策权。
本发明方法中,对新加入该系统的服务器赋予优先级,当赋予其的优先级为最高时,将其服务器中所存的数据转发至其它服务器;当赋予其的优先级低于最高时,该服务器从系统内优先级最高的服务器中获取与己不同的数据。
与现有技术相比,本发明通过对系统内所有服务器赋予不同的优先级,当某一用户终端提出修改或更改数据的请求后,该请求须经系统中优先级最高的服务器审核、批准、备案,之后,由该优先级最高的服务器将备案信息经各服务器传递并转发至其它所有的服务器中,由此,使得该分布式网络系统中的所有服务器拥有相同的数据并且实时同步。
附图说明
图1为分布式网络系统示意图。
图2为本发明的系统中各服务器互通优先级等级的示意图。
图3为本发明的系统中服务器接收优先级通告报文处理流程图。
图4为本发明的系统中各服务器处理用户终端请求的流程图。
图5为本发明的系统中服务器收到重复或自发报文的示意图。
具体实施方式
下面结合附图对本发明作进一步说明。
如图1所示,其描述的是一个由四台服务器组成的分布式系统。这四台服务器上的数据是一致的。用户可以向任意一台服务器提交修改数据的请求,也就是对于用户来说,不必区分具体的服务器,认为凡是属于该系统的服务器都是没有区别的。
一、本发明的分布式实时同步网络系统具备的特点是:
1)系统由若干台服务器通过网络连接。
2)在任何时候,都可能有新的服务器加入该系统,或者系统中的一台服务器退出该系统。
3)该系统中的任何一台服务器的数据一致并实时同步。
二、如图2、3、4所示,搭建本发明系统的关键技术如下:
1、系统中所有的服务器都需要事先设定一个优先级,并且所有的服务器的优先级不能出现重复。每台服务器都定时向其他设备通告自己的优先级。那么每台服务器都知道在系统中,自己的优先级是否是最高的。
某台服务器优先级高低的设定,可由系统管理员根据网络条件、配置程度或网速快慢确定。
2、当一台服务器收到用户请求的时候,如果自己不是优先级最高的服务器,就需要把该请求向邻居转发。直到优先级最高的服务器收到该请求,才能对该请求进行处理。整个系统只有一台服务器的优先级最高,那么所有的请求都被提交到该服务器上进行处理,也就完成了对不同服务器所接收到的请求的排序。
3、在最高优先级的服务器处理了一个用户的请求之后,就向所有的邻居发送处理的结果。所有接收到处理结果的邻居,也需要向其他邻居转发该处理结果。这样,一个请求的处理结果就被同步到整个系统中的所有服务器上。
4、在新的服务器加入该系统的时候,如果该服务器是最高优先级,那么整个系统的数据都会以该服务器为准;该服务器在获知自己是最高优先级的服务器的时候,会把自己本地的数据同步到所有的邻居,邻居服务器收到数据之后,会同步到所有的其他邻居。
5、如果新加入的服务器的优先级不是最高,那么最高优先级的服务器感知到有新的服务器加入,就会重新把本地的数据发送到新的服务器。
6、当有服务器不能正常工作,如果该服务器的优先级不是最高,那么不会对该系统造成任何影响。如果该服务器的优先级是最高的,那么整个系统就需要重新确定一个最高优先级的服务器。
三、本发明的系统通告报文的方法如下:
1)服务器在启动的时候,不拥有决策权,会设置一个定时器。如果该定时器在T时间之后顺利触发,该服务器自动获得决策权。
2)服务器会向所有的邻居发送自己的优先级通告,服务器在接受到来自邻居的优先级通告报文之后,也会向其他服务器转发该通告。这样就不会限制整个系统的拓扑连接方式。只要任何两台服务器之间有路径可达,彼此的通告就可以发送到对方。
3)一台服务器在收到其他服务器的优先级通告之后,和本地的优先级进行比较。如果本地的优先级更高,忽略该报文。如果本地的优先级更低并且不拥有决策权,则重新设置获取决策权的定时器。如果本地的优先级更低并且拥有决策权,该服务器就放弃决策权,同时设置获取决策权的定时器。
4)分布式系统中的某台服务器,在收到用户的请求之后,如果本地拥有决策权,本地就可以处理该请求,把请求的回应发送给用户,同时把处理请求之后的生效内容发送给其他服务器。如果本地没有决策权,就会保留一份该请求,同时转发到其他服务器。按照这种转发的顺序,直到拥有最高的决策权的服务器接收到了请求,完成了处理,再按照请求的路径发送回应,直到用户收到该回应。同时再向其他的服务器发送处理请求之后的生效内容。
用户提交的请求,会最终转发到拥有决策权的服务器。该服务器处理完请求之后,会给出请求的回应(成功或者失败)。请求的回应的发送路径,是按照请求的转发路径逆向发送的。在服务器转发请求报文的时候,会记录该请求来自哪个相连的服务器。该记录会有一定生存周期,超过这个周期就认为是请求处理已经超时。拥有最高优先级在处理了请求之后,把处理的结果发回请求的直接来源服务器。接收到回应的服务器在本地找出该请求的来源,把该回应发送给直接相连的源服务器。重复这样的流程一直到用户接收到请求的回应为止。
决策权服务器在处理完请求,向转发请求的服务器发送了请求回应之后,会向所有的服务器发送请求的生效结果。其他服务器在接收到生效的结果后,更新本地的数据,然后向其他服务器转发。
5)优先级通告以及数据修改请求报文都需要包含以下内容:服务器的唯一标识,报文的序列号。分布式系统中,每个服务器都有一个唯一的标识。服务器在产生优先级通告报文,以及接收到用户请求,产生请求报文的时候,都会生成新的报文的序列号。服务器在转发优先级通告报文以及用户请求的时候,不会修改报文中的设备唯一标识以及报文序列号字段。服务器的唯一标识和报文序列号能够唯一确定系统中的报文。
6)在存在环状路径的网络系统中,一台服务器有可能接收到重复的报文,以及自身发出的报文被转发回自身(如图5所示),该报文包括优先级通告、请求报文以及请求的处理结果等。为了处理这种情况,服务器需要保存最近一段时间内的报文字段(主要是服务器ID和报文序号)。这些历史报文信息以HASH表的方式保存起来,每收到一个新报文,就需要查看HASH表,如果该报文属于重复收到的报文,以及是本服务器曾经发送出去的报文,就会被丢弃。
7)如果拥有决策权的设备退出系统,意味着和系统中的其他设备断开连接。系统中剩下的服务器中的优先级最高的服务器,在定时器超时被触发之后,自动获取了决策权。
8)如果管理员想让一个新服务器加入一个分布式系统,并且仍然使用该分布式系统正在运行的数据,就可以把该服务器的优先级设置的比较低,再加入该系统。和该新服务器建立连接的服务器会发送一份完整的数据给新加入的服务器。该服务器获得了完整的数据之后,覆盖本地的数据,和其他服务器一起,作为分布式系统的一个组成部分开始运行。
9)如果管理员希望正在运行的分布式系统采用新加入的服务器所带有的数据,就把该新服务器的优先级设置为最高。服务器在加入分布式系统之后,会获取决策权,在获取决策权之后,会向系统内的其他服务器发送自身的数据。其他服务器得到拥有决策权的服务器的数据之后,会覆盖本地的数据,同时向其他服务器转发。这个过程会一直持续到系统内的所有服务器的数据都一致为止。
四、技术要点
1、决策点的选举,该技术要点是以下几个技术的合成:
1)每台服务器都有一个优先级,都要向其他服务器发送优先级报文,以通告自己的优先级;同时收到该报文的服务器需要向自己的邻居转发该报文。
2)每台服务器都需要设置一个历史报文信息缓存,以过滤在转发过程中收到的重复的报文。
3)每台服务器如果得知存在更高的优先级服务器,主动放弃决策权。
4)每台不拥有决策权的服务器都设置一个定时器,超过一定时间没有收到比自己更高优先级的服务器信息,就设置自己为决策点服务器。
2、回应请求的路径的确定,该技术是以下几个技术的合成:
1)每个请求都包含发出请求的服务器标识和该报文的序列号。并且该请求在被其他服务器转发的过程中,是不会被修改的。
2)服务器在转发某个请求的时候,会保存该请求的服务器标识和报文的序列号,以及该请求是从哪个邻居发送过来的。
3)决策点服务器在处理完该请求之后,发送的回应报文中,携带了发起该请求的服务器标识以及请求报文的序列号。
4)一台服务器接收到请求的回应报文之后,根据回应报文中携带的服务器标识和报文的序列号,确定该回应所对应的请求是来自于哪个邻居,然后把回应转发给该邻居。
5)在转发请求的过程中,所缓存的请求信息是有时间限制的,超时之后,就不再生效。
Claims (9)
1.一种分布式实时同步网络系统,包括若干台服务器和连接在各服务器上的用户终端,其特征在于:该系统内的所有服务器所存数据相同且对每一个服务器赋予不同的优先级,其中,
1)每台服务器均定时向相邻的服务器通报本服务器的优先级;每台服务器在收到邻居服务器的优先级通告之后,向除该优先级通告发出服务器之外的其他邻居服务器转发该通告;
2)优先级低的服务器将其用户终端提出的请求信息传递给优先级最高的服务器,或者通过相邻服务器依次直到转发给优先级最高的服务器;
3)所述请求信息经所述优先级最高的服务器备案后,将该备案信息经相邻服务器转发至该系统的每台服务器中并使所有服务器保持相同的存储数据。
2.根据权利要求1所述的分布式实时同步网络系统,其特征在于:对新加入该系统的服务器赋予优先级,当赋予其的优先级为最高时,将其服务器中所存的数据转发至其它服务器;当赋予其的优先级低于最高时,该服务器从系统内优先级最高的服务器中获取与己不同的数据。
3.根据权利要求1所述的分布式实时同步网络系统,其特征在于:所述最高优先级的服务器退出该系统后,该系统重新设定优先级最高的服务器。
4.根据权利要求1-3中任一项所述的分布式实时同步网络系统,其特征在于:在每台服务器中设有过滤再次收到的所述备案信息的历史报文信息缓存器。
5.一种分布式实时同步网络系统内通告数据的方法,其特征在于:按以下步骤执行:
1)该系统中每台服务器启动时,均会获取优先级,同时,其内部会自动产生一个定时器,在服务器收到比自己更高的优先级通告之后,会延迟定时器的触发时间,当该定时器在T时间被触发后,该服务器自动成为该系统中优先级最高的服务器而获得决策权;
2)每台服务器均定时向其它服务器通报本服务器的优先级并随时接收其它服务器优先级通告报文,之后向邻居服务器转发来自其它服务器的优先级通告报文;
3)当一台服务器收到其他服务器的优先级通告后,经与本地优先级比较,若本地优先级为系统中最高,则忽略该报文;若本地优先级较低且不拥有决策权,则重新设置获取决策权的定时器;若本地优先级较低且拥有决策权,则放弃决策权,同时设置定时器;
4)优先级低的服务器将其用户终端提出的请求信息传递给优先级最高的服务器,或者通过相邻服务器依次直到转发给优先级最高的服务器;
5)所述请求信息经所述优先级最高的服务器备案后,将该备案信息经相邻服务器转发至该系统的每台服务器中并使所有服务器保持相同的存储数据。
6.根据权利要求5所述的方法,其特征在于:优先级通告报文包含以下内容:服务器的唯一标识和每次报文生成的序列号。
7.根据权利要求5所述的方法,其特征在于:在具有环状路径的网络系统中,在每台服务器中设有过滤再次收到的所述通告报文的历史报文信息缓存器。
8.根据权利要求5所述的方法,其特征在于:拥有决策权的服务器或用户终端退出该系统,系统中某服务器内部的定时器超时被触发之后,自动成为优先级最高的服务器并获取决策权。
9.根据权利要求5所述的方法,其特征在于:对新加入该系统的服务器赋予优先级,当赋予其的优先级为最高时,将其服务器中所存的数据转发至其它服务器;当赋予其的优先级低于最高时,该服务器从系统内优先级最高的服务器中获取与己不同的数据。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410334955.0A CN104079663B (zh) | 2014-07-15 | 2014-07-15 | 分布式实时同步网络系统及其通告数据的方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410334955.0A CN104079663B (zh) | 2014-07-15 | 2014-07-15 | 分布式实时同步网络系统及其通告数据的方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN104079663A true CN104079663A (zh) | 2014-10-01 |
CN104079663B CN104079663B (zh) | 2017-11-17 |
Family
ID=51600703
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201410334955.0A Active CN104079663B (zh) | 2014-07-15 | 2014-07-15 | 分布式实时同步网络系统及其通告数据的方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN104079663B (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108170763A (zh) * | 2017-12-25 | 2018-06-15 | 江南大学 | 一种低延迟的分布式计算共识算法 |
CN108366086A (zh) * | 2017-12-25 | 2018-08-03 | 聚好看科技股份有限公司 | 一种控制业务处理的方法及装置 |
CN108650281A (zh) * | 2018-02-28 | 2018-10-12 | 努比亚技术有限公司 | 一种数据管理方法、装置及计算机可读存储介质 |
CN109491715A (zh) * | 2018-11-06 | 2019-03-19 | 深圳市风云实业有限公司 | 基于Windows NT的应用管理方法、装置及终端 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6944788B2 (en) * | 2002-03-12 | 2005-09-13 | Sun Microsystems, Inc. | System and method for enabling failover for an application server cluster |
CN103067206A (zh) * | 2012-12-28 | 2013-04-24 | 无锡博欧节能科技有限公司 | 物联网跨机房分布式全自动热备用服务器切换系统 |
-
2014
- 2014-07-15 CN CN201410334955.0A patent/CN104079663B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6944788B2 (en) * | 2002-03-12 | 2005-09-13 | Sun Microsystems, Inc. | System and method for enabling failover for an application server cluster |
CN103067206A (zh) * | 2012-12-28 | 2013-04-24 | 无锡博欧节能科技有限公司 | 物联网跨机房分布式全自动热备用服务器切换系统 |
Non-Patent Citations (2)
Title |
---|
NAVIN BUDHIRAJA ET AL: "Primary-Backup Protocols: Lower Bounds and Optimal Implementations", 《DEPENDABLE COMPUTING FOR CRITIACL APPLICATIONS 3 》 * |
SANG SOO KIM: "Primary-Backup Systems", 《SLIDESERVER》 * |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108170763A (zh) * | 2017-12-25 | 2018-06-15 | 江南大学 | 一种低延迟的分布式计算共识算法 |
CN108366086A (zh) * | 2017-12-25 | 2018-08-03 | 聚好看科技股份有限公司 | 一种控制业务处理的方法及装置 |
CN108170763B (zh) * | 2017-12-25 | 2021-07-27 | 江南大学 | 一种低延迟的分布式计算共识算法 |
CN108650281A (zh) * | 2018-02-28 | 2018-10-12 | 努比亚技术有限公司 | 一种数据管理方法、装置及计算机可读存储介质 |
CN109491715A (zh) * | 2018-11-06 | 2019-03-19 | 深圳市风云实业有限公司 | 基于Windows NT的应用管理方法、装置及终端 |
CN109491715B (zh) * | 2018-11-06 | 2021-10-22 | 深圳市风云实业有限公司 | 基于Windows NT的应用管理方法、装置及终端 |
Also Published As
Publication number | Publication date |
---|---|
CN104079663B (zh) | 2017-11-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107332876B (zh) | 区块链状态的同步方法及装置 | |
US9723583B2 (en) | Masterless slot allocation | |
CN108881354B (zh) | 一种推送信息存储方法、装置、服务器和计算机存储介质 | |
US20220321423A1 (en) | Methods, apparatus and machine-readable media relating to machine-learning in a communication network | |
US20100302954A1 (en) | Distributed information storage and retrieval of communication network performance data | |
CN109040184B (zh) | 一种主节点的选举方法及服务器 | |
CN104468163A (zh) | 容灾网络组网的方法、装置及容灾网络 | |
CN104079663A (zh) | 分布式实时同步网络系统及其通告数据的方法 | |
TW201737107A (zh) | 資料的同步方法和裝置 | |
CN106611001A (zh) | 虚拟机数据库表数据一致性的校验方法、装置及系统 | |
CN110247980B (zh) | 一种局域网中的网关控制方法及网关 | |
CN113434312A (zh) | 数据血缘关系处理方法及装置 | |
CN104506330A (zh) | 一种消息同步方法和系统 | |
CN110708177B (zh) | 分布式系统中的异常处理方法、系统和装置 | |
CN104869253A (zh) | 一种移动终端连接智能试衣镜的方法及系统 | |
US10853892B2 (en) | Social networking relationships processing method, system, and storage medium | |
CN105141687B (zh) | 一种生产消息的方法 | |
CN103685497A (zh) | 一种在线存储共享方法和系统 | |
CN113422623B (zh) | 一种管理方法、系统、装置、电子设备及存储介质 | |
CN107819684B (zh) | 同步处理方法及装置 | |
CN102647424A (zh) | 一种数据传输方法及其装置 | |
CN114884805A (zh) | 数据传输方法、装置、终端及存储介质 | |
JP2016502374A (ja) | 自動的にx2構成を削除するための方法、基地局、及びネットワークシステム | |
Saghian et al. | Publish/subscribe middleware for resource discovery in MANET | |
CN105187472A (zh) | 数据同步方法及装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |