CN102291416B - 一种客户端与服务器端双向同步的方法及系统 - Google Patents

一种客户端与服务器端双向同步的方法及系统 Download PDF

Info

Publication number
CN102291416B
CN102291416B CN201110271644.0A CN201110271644A CN102291416B CN 102291416 B CN102291416 B CN 102291416B CN 201110271644 A CN201110271644 A CN 201110271644A CN 102291416 B CN102291416 B CN 102291416B
Authority
CN
China
Prior art keywords
data
application client
server end
client
apps server
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.)
Active
Application number
CN201110271644.0A
Other languages
English (en)
Other versions
CN102291416A (zh
Inventor
王献昌
罗祖麦
王玉稳
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Soft-Intelligent Technology (chengdu) Co Ltd
Original Assignee
Soft-Intelligent Technology (chengdu) Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Soft-Intelligent Technology (chengdu) Co Ltd filed Critical Soft-Intelligent Technology (chengdu) Co Ltd
Priority to CN201110271644.0A priority Critical patent/CN102291416B/zh
Publication of CN102291416A publication Critical patent/CN102291416A/zh
Application granted granted Critical
Publication of CN102291416B publication Critical patent/CN102291416B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Abstract

本发明公开了一种客户端与服务器端双向同步的方法及系统,所述方法包括,应用程序服务器端接收到应用程序客户端发送的业务请求后,对业务请求进行解析;所述应用程序服务器端判断若一应用程序客户端修改了一对象的数据后,则根据应用程序客户端信息及其订阅的对象的信息的表格中的信息,查找订阅了该对象的应用程序客户端,判断若找到,则将修改后的该对象的数据发送到相应应用程序客户端,保持客户端与服务器端的数据同步。本发明能在对象发生变化后服务器端在第一时间把更新的数据发送给各个客户端,使客户端与服务器端的数据同步效果得到进一步提升。

Description

一种客户端与服务器端双向同步的方法及系统
技术领域
本发明涉及网络传输技术,更具体地,本发明涉及一种客户端与服务器端双向同步的方法及系统。
背景技术
在传统网络应用程序的C/S架构中,客户端(C)作为服务器端(S)的数据展示和操作端:它通过网络连接到服务器端(S),然后读取相应的数据(O)进行显示和操作。显示时,客户端需要定期的刷新(重新读取服务器的最新数据)当前显示的数据,以保持与服务器上的数据一致。在操作时,需要把操作命令发送到服务器端,然后在服务器上执行命令并根据返回结果更新客户端数据。
这种传统的客户端与服务器端的数据同步有以下一些缺点:
1.当系统中有多个客户端(C)的时候,服务器上的数据对象更新可能比较频繁,这种情况下,由于客户端是定期刷新数据,客户端与服务器端的数据会有延迟,会导致一些客户端正在操作的数据在服务器端已经被修改了,从而导致操作失败。
2.由于客户端是通过定期刷新服务器来更新本地数据的,而无论服务器端数据是否有更新,即客户端的数据更新是被动的。当系统中有大量的客户端时,就会降低服务器的效率,浪费服务器资源。
在一些大型的软件系统中,由于业务逻辑复杂,系统中抽象出来的业务逻辑对象数量众多,且对象之间常常互相关联。在传统的三层软件架构中,客户端的处理请求会提交给服务器,服务器负责处理请求,服务器在处理请求的过程中若需要获取某对象的数据就会从数据库中读取生成对象发送到客户端,若要修改某对象则在修改后需要在数据库中更新此对象的数据。在有多个客户端的时候,客户端与服务器端的数据同步就是一个问题。传统的是通过客户端定时刷新服务器数据,以达到数据同步的目的,是一种被动式的数据同步方式。若刷新频率高,客户端与服务器数据能得到较好的同步,但由于刷新频率高,而且很多时候服务器的对象并没有更新,会降低服务器的处理效率和性能,浪费服务器资源。若刷新频率低,则客户端与服务器端的数据同步效果不好。
因此当前需要一种新的客户端与服务器端双向同步的技术方案来解决上述问题。
发明内容
本发明所要解决的技术问题是提供一种客户端与服务器端双向同步的方法及系统,解决了当前客户端与服务器端同步时,服务器端负载过大的问题。
为了解决上述问题,本发明提供    一种客户端与服务器端双向同步的系统,包括:一个或多个应用程序客户端和应用程序服务器端,所述应用程序客户端,用于向应用程序服务器端发送业务请求;所述应用程序服务器端还包括:请求接收模块、对象订阅模块、对象发布模块和对象更新检测模块,其中,
所述请求接收模块,用于接收所述业务请求,并对业务请求进行解析、分发;
所述对象订阅模块,用于维护一应用程序客户端信息及其订阅的对象的信息的表格,该表格记录了每个应用程序客户端需要进行数据同步的相关信息;
    所述对象更新检测模块,用于检测若一应用程序客户端修改了一对象的数据,若是,则将修改后的对象发送给对象发布模块进行处理;
所述对象发布模块,用于接收所述对象更新检测模块发送的修改后的对象,根据该对象的信息对所述对象订阅模块维护的表格中查找订阅了该对象的应用程序客户端,判断若找到,则将修改后的该对象的数据发送到相应应用程序客户端,保持客户端与服务器端的数据同步。
优选地,所述对象订阅模块 维护的所述表格,包括:应用程序客户端名称、应用程序客户端地址、应用程序客户端通信端口及其订阅的对象列表的信息;
所述对象更新检测模块,还用于检测应用程序服务器端中对象的数据是否发生变化,若是,则将修改后的对象发送给对象发布模块进行处理;
所述对象发布模块,用于接收所述对象更新检测模块发送的修改后的对象,根据该对象的名称对所述对象订阅模块维护的表格中查找订阅了该对象的应用程序客户端,判断若找到,则对更新后对象的数据进行封装后,将封装后的对象的数据根据应用程序客户端的地址和通信端口,发送到相应应用程序客户端。
优选地,所述应用程序服务器端还包括:业务逻辑处理模块和业务逻辑对象管理模块,其中,
所述业务逻辑处理模块,用于接收所述请求接收模块发送的所述业务请求,判断如果在进行业务处理的过程中更新或删除了应用程序服务器端中的某对象,则通知其它模块有对象进行了更新,在处理完一业务请求后会将处理结果返回到所述请求接收模块;
所述业务逻辑对象管理模块,用于管理应用程序服务器端上所有的业务逻辑对象,包括对对象的查询、更新和删除操作。
优选地,还包括数据库端,该数据库端包括:数据库实时监控程序单元和数据库单元,其中,
所述数据库实时监控程序单元,用于监控所述数据库单元中的相应数据表,该数据表记录了由应用程序客户端直接对数据库单元中的基础数据进行操作后数据的变化情况,根据变化情况生成基础数据更新请求后,发送到服务器端的基础数据更新模块;
所述数据库单元,用于存储数据;
所述应用程序服务器端进一步包括:数据库操作模块和基础数据更新模块,其中,
所述数据库操作模块,用于与所述数据库单元进行交互,在应用程序服务器端启动时从所述数据库单元中读取需要的数据后,构造成各种业务逻辑对象;判断若应用程序服务器端对业务逻辑对象进行修改时,将修改后的数据写入所述数据库单元,以保持数据的一致性;
所述基础数据更新模块,用于接收所述数据库实时监控程序单元发送的基础数据更新请求后,根据该更新请求来更新相应的业务逻辑对象。
以及提供了一种客户端与服务器端双向同步的方法,包括:
应用程序服务器端接收到应用程序客户端发送的业务请求后,对业务请求进行解析;
所述应用程序服务器端判断若一应用程序客户端修改了一对象的数据后,则根据应用程序客户端信息及其订阅的对象的信息的表格中的信息,查找订阅了该对象的应用程序客户端,判断若找到,则将修改后的该对象的数据发送到相应应用程序客户端,保持客户端与服务器端的数据同步。
优选地,所述应用程序客户端信息及其订阅的对象的信息的表格,包括:应用程序客户端名称、应用程序客户端地址、应用程序客户端通信端口及其订阅的对象列表的信息。
优选地,还包括:所述应用程序服务器端检测对象的数据是否发生变化,若是,则根据该对象的名称在所述表格中查找订阅了该对象的应用程序客户端,判断若找到,则对更新后对象的数据进行封装后,将封装后的对象的数据根据应用程序客户端的地址和通信端口,发送到相应应用程序客户端。
优选地,还包括:所述应用程序服务器端接收到所述业务请求后,判断如果在进行业务处理的过程中更新或删除了应用程序服务器端中的某对象,则对所述表格进行相应更新,并记录对该对象的查询、更新和删除操作。
优选地,进一步包括:所述应用程序服务器端在启动时从数据库中读取需要的数据后,构造成各种业务逻辑对象;判断若修改了业务逻辑对象,并将修改后的数据写入数据库,以保持数据的一致性。
优选地,进一步包括:所述应用程序服务器端监控数据库中的相应数据表,该数据表记录了由应用程序客户端直接对数据库中的基础数据进行操作后数据的变化情况,根据该变化情况更新相应的业务逻辑对象。
与现有技术相比,应用本发明,避免了客户端定时向服务器端进行刷新操作,减轻了服务器端负担,提高了服务器端的处理效率和性能;而且服务器端是主动发起的数据同步的请求,当对象发生变化后服务器端会在第一时间把更新的数据发送给各个客户端,使客户端与服务器端的数据同步效果得到进一步提升。
附图说明
图1是本发明的客户端与服务器端双向同步的系统示意图;
图2是本发明的客户端与服务器端双向同步的方法的流程图。
具体实施方式
下面结合附图和具体实施方式对本发明作进一步说明。
本发明为了提高应用服务器处理业务逻辑的效率和性能,通常在应用服务器启动时就会预先把系统要处理的各种业务逻辑对象的数据从数据库中读到服务器来,并生成相应的服务器对象,每一个对象(即使是不同类的对象)都拥有唯一的名称(ID),在客户端发送到服务器端的请求中会有一个订阅标识位,此标识位表示客户端是否需要对这个请求中涉及到的对象进行数据同步。若需要同步,则服务器会记录发送此请求的客户端的IP地址、端口、版本号、订阅的对象ID号等信息,这些记录在服务器端形成一个列表。当服务器发现某个对象更新时,就会去查找此列表,会给订阅了这些对象同步请求的客户端发送更新了的对象数据(客户端需要创建一个端口监听来自服务器端的对象更新消息)。从而实现了客户端与服务器端数据的同步。这种数据同步的方案是由服务器作为主动发起方, 是一种主动式的数据同步方式。客户端需要定时的发送心跳包以使服务器知道客户端的活动状态。
如图1所示,一种客户端与服务器端双向同步的系统,包括:一个或多个应用程序客户端、应用程序服务器端和数据库端,
所述应用程序客户端,用于向应用程序服务器端发送业务请求;所述应用程序服务器端还包括:请求接收模块、对象订阅模块、对象发布模块、对象更新检测模块、业务逻辑处理模块和业务逻辑对象管理模块、数据库操作模块和基础数据更新模块,其中,
所述请求接收模块,用于接收所述业务请求,并对业务请求进行解析、分发;
所述对象订阅模块,用于维护一应用程序客户端信息及其订阅的对象的信息的表格,该表格记录了每个应用程序客户端需要进行数据同步的相关信息;
所述对象更新检测模块,用于检测若一应用程序客户端修改了一对象的数据,若是,则将修改后的对象发送给对象发布模块进行处理;
所述对象发布模块,用于接收所述对象更新检测模块发送的修改后的对象,根据该对象的信息对所述对象订阅模块维护的表格中查找订阅了该对象的应用程序客户端,判断若找到,则将修改后的该对象的数据发送到相应应用程序客户端,保持客户端与服务器端的数据同步;
所述业务逻辑处理模块,用于接收所述请求接收模块发送的所述业务请求,判断如果在进行业务处理的过程中更新或删除了应用程序服务器端中的某对象,则通知其它模块有对象进行了更新,在处理完一业务请求后会将处理结果返回到所述请求接收模块;
所述业务逻辑对象管理模块,用于管理应用程序服务器端上所有的业务逻辑对象,包括对对象的查询、更新和删除操作;
所述数据库操作模块,用于与所述数据库单元进行交互,在应用程序服务器端启动时从所述数据库单元中读取需要的数据后,构造成各种业务逻辑对象;判断若应用程序服务器端对业务逻辑对象进行修改时,将修改后的数据写入所述数据库单元,以保持数据的一致性;
所述基础数据更新模块,用于接收所述数据库实时监控程序单元发送的基础数据更新请求后,根据该更新请求来更新相应的业务逻辑对象。
所述对象订阅模块     维护的所述表格,包括:应用程序客户端名称、应用程序客户端地址、应用程序客户端通信端口及其订阅的对象列表的信息。如表1所示:
客户端ID 客户端地址 客户端通信端口 订阅的对象列表
1 192.168.1.12 8000 Obj1,obj2,obj3….objn
2 192.168.1.16 8000 Obj1,obj2
…… …… …… ……
N 192.168.100.10 8000 Obj1,obj2,obj3…objn
所述对象更新检测模块,还用于检测应用程序服务器端中对象的数据是否发生变化,若是,则将修改后的对象发送给对象发布模块进行处理;
所述对象发布模块,用于接收所述对象更新检测模块发送的修改后的对象,根据该对象的名称对所述对象订阅模块维护的表格中查找订阅了该对象的应用程序客户端,判断若找到,则对更新后对象的数据进行封装后,将封装后的对象的数据根据应用程序客户端的地址和通信端口,发送到相应应用程序客户端。
所述数据库端包括:数据库实时监控程序单元和数据库单元,其中,
所述数据库实时监控程序单元,用于监控所述数据库单元中的相应数据表,该数据表记录了由应用程序客户端直接对数据库单元中的基础数据进行操作后数据的变化情况,根据变化情况生成基础数据更新请求后,发送到服务器端的基础数据更新模块;
所述数据库单元,用于存储数据;
下面是图1中本发明的系统的各模块之间的工作流程的描述,包括:
1.从数据库单元中读取数据到应用程序服务器端中。
2.在应用程序服务器端中把从数据库单元中读取的数据构造成业务逻辑对象。
3.应用程序客户端发送一个业务请求到应用程序服务器端。
4.应用程序服务器端的请求接收模块接收到一个请求,并解析请求,把请求中的有关对象的订阅信息发送到对象订阅模块中。
5.请求接收模块把应用程序客户端请求转发到业务逻辑处理模块中进行处理。
6.业务逻辑处理模块在处理请求的过程中需要更新相关对象。
7.对象发生变化,通知数据库操作模块对数据库单元中的相关数据进行修改。
8.数据库操作模块把相关数据写入数据库单元。
9.业务逻辑处理模块在处理请求的过程中需要读取相关对象。
10.业务逻辑处理模块在处理应用程序客户端请求的过程中改变了对象,通知对象更新检测模块。
11.业务逻辑处理模块处理完应用程序客户端请求后返回处理结果到请求接收模块中。
12.请求接收模块把请求的处理结果转发到发送请求的应用程序客户端中。
13.对象更新检测模块检测到有对象发生变化。
14.对象更新检测模块把变化后的对象发送到对象发布模块。
15.对象发布模块根据变化的对象的ID号到对象订阅模块中进行查询,得到订阅了这些对象同步的应用程序客户端信息。
16.对象发布模块根据应用程序客户端的信息把变化后的对象发送到相应的应用程序客户端。
17.应用程序客户端直接连接数据库单元,修改基础数据(即不需要进行额外的业务逻辑处理的数据,直接从数据库表中进行增、删、查)。
18.数据库实时监控程序单元不断的监控数据库单元,检测应用程序客户端是否对基础数据进行了改变。
19.数据库实时监控程序单元检测到有基础数据发生了变化,从数据库单元中读取相应的变化数据。
20.数据库实时监控程序单元把读取的基础数据变化数据发送到应用程序服务器端中的基础数据更新模块。
21.基础数据更新模块根据变化的数据进行相应的封装,然后更新与之有关联的对象,从而保证应用程序服务器端中的对象与数据库单元中的相应数据一致。
22.基础数据更新模块通知对象更新检测模块有对象发生变化。
如图2所示,本发明的一种客户端与服务器端双向同步的方法,包括:
步骤210、应用程序服务器端接收到应用程序客户端发送的业务请求后,对业务请求进行解析;
步骤220、所述应用程序服务器端判断若一应用程序客户端修改了一对象的数据后,则根据应用程序客户端信息及其订阅的对象的信息的表格中的信息,查找订阅了该对象的应用程序客户端,判断若找到,则将修改后的该对象的数据发送到相应应用程序客户端,保持客户端与服务器端的数据同步。
所述应用程序客户端信息及其订阅的对象的信息的表格,包括:应用程序客户端名称、应用程序客户端地址、应用程序客户端通信端口及其订阅的对象列表的信息。
还包括:所述应用程序服务器端检测对象的数据是否发生变化,若是,则根据该对象的名称在所述表格中查找订阅了该对象的应用程序客户端,判断若找到,则对更新后对象的数据进行封装后,将封装后的对象的数据根据应用程序客户端的地址和通信端口,发送到相应应用程序客户端。
还包括:所述应用程序服务器端接收到所述业务请求后,判断如果在进行业务处理的过程中更新或删除了应用程序服务器端中的某对象,则对所述表格进行相应更新,并记录对该对象的查询、更新和删除操作。
进一步包括:所述应用程序服务器端在启动时从数据库中读取需要的数据后,构造成各种业务逻辑对象;判断若修改了业务逻辑对象,并将修改后的数据写入数据库,以保持数据的一致性。
进一步包括:所述应用程序服务器端监控数据库中的相应数据表,该数据表记录了由应用程序客户端直接对数据库中的基础数据进行操作后数据的变化情况,根据该变化情况更新相应的业务逻辑对象。
以上所述,仅为本发明较佳的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉该技术的人在本发明所揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应该以权利要求的保护范围为准。

Claims (10)

1.一种客户端与服务器端双向同步的系统,包括:一个或多个应用程序客户端和应用程序服务器端,其特征在于,
所述应用程序客户端,用于向应用程序服务器端发送业务请求;所述应用程序服务器端还包括:请求接收模块、对象订阅模块、对象发布模块和对象更新检测模块,其中,
所述请求接收模块,用于接收所述业务请求,并对业务请求进行解析、分发;
所述对象订阅模块,用于维护一应用程序客户端信息及其订阅的对象的信息的表格,该表格记录了每个应用程序客户端需要进行数据同步的相关信息;
所述对象更新检测模块,用于检测若一应用程序客户端修改了一对象的数据,若是,则将修改后的对象发送给对象发布模块进行处理;
所述对象发布模块,用于接收所述对象更新检测模块发送的修改后的对象,根据该对象的信息对所述对象订阅模块维护的表格中查找订阅了该对象的应用程序客户端,判断若找到,则将修改后的该对象的数据发送到相应应用程序客户端,保持客户端与服务器端的数据同步;
所述应用程序服务器端启动时预先把系统要处理的各种业务逻辑对象的数据从数据库中读到应用程序服务器端,并生成相应的服务器对象,每一个对象都拥有唯一的名称,在所述应用程序客户端发送到所述应用程序服务器端的请求中有一个订阅标识位,此标识位表示所述应用程序客户端是否需要对这个请求中涉及到的对象进行数据同步;若需要同步,当所述应用程序服务器端发现某个对象更新时,给订阅了这些对象同步请求的所述应用程序客户端发送更新了的对象数据;所述应用程序服务器端作为主动发起方,所述应用程序客户端定时的发送心跳包以使所述应用程序服务器知道所述应用程序客户端的活动状态。
2.如权利要求1所述的系统,其特征在于,
所述对象订阅模块维护的所述表格,包括:应用程序客户端名称、应用程序客户端地址、应用程序客户端通信端口及其订阅的对象列表的信息;
当所述应用程序客户端需要对所述请求中涉及到的对象进行数据同步时,所述应用程序服务器端记录发送此请求的所述应用程序客户端信息,记录在所述应用程序服务器端的信息形成所述表格,所述信息包括所述应用程序客户端的IP地址、端口、订阅的对象ID号;当所述应用程序服务器端发现某个对象更新时,查找所述表格,获得订阅了这些对象同步请求的所述应用程序客户端的信息;
所述对象更新检测模块,还用于检测应用程序服务器端中对象的数据是否发生变化,若是,则将修改后的对象发送给对象发布模块进行处理;
所述对象发布模块,用于接收所述对象更新检测模块发送的修改后的对象,根据该对象的名称对所述对象订阅模块维护的表格中查找订阅了该对象的应用程序客户端,判断若找到,则对更新后对象的数据进行封装后,将封装后的对象的数据根据应用程序客户端的地址和通信端口,发送到相应应用程序客户端。
3.如权利要求1所述的系统,其特征在于,
所述应用程序服务器端还包括:业务逻辑处理模块和业务逻辑对象管理模块,其中,
所述业务逻辑处理模块,用于接收所述请求接收模块发送的所述业务请求,判断如果在进行业务处理的过程中更新或删除了应用程序服务器端中的某对象,则通知其它模块有对象进行了更新,在处理完一业务请求后会将处理结果返回到所述请求接收模块;
所述业务逻辑对象管理模块,用于管理应用程序服务器端上所有的业务逻辑对象,包括对对象的查询、更新和删除操作。
4.如权利要求1所述的系统,其特征在于,
还包括数据库端,该数据库端包括:数据库实时监控程序单元和数据库单元,其中,
所述数据库实时监控程序单元,用于监控所述数据库单元中的相应数据表,该数据表记录了由应用程序客户端直接对数据库单元中的基础数据进行操作后数据的变化情况,根据变化情况生成基础数据更新请求后,发送到服务器端的基础数据更新模块;
所述数据库单元,用于存储数据;
所述应用程序服务器端进一步包括:数据库操作模块和基础数据更新模块,其中,
所述数据库操作模块,用于与所述数据库单元进行交互,在应用程序服务器端启动时从所述数据库单元中读取需要的数据后,构造成各种业务逻辑对象;判断若应用程序服务器端对业务逻辑对象进行修改时,将修改后的数据写入所述数据库单元,以保持数据的一致性;
所述基础数据更新模块,用于接收所述数据库实时监控程序单元发送的基础数据更新请求后,根据该更新请求来更新相应的业务逻辑对象。
5.一种客户端与服务器端双向同步的方法,其特征在于,包括:
应用程序服务器端接收到应用程序客户端发送的业务请求后,对业务请求进行解析;
所述应用程序服务器端判断若一应用程序客户端修改了一对象的数据后,则根据应用程序客户端信息及其订阅的对象的信息的表格中的信息,查找订阅了该对象的应用程序客户端,判断若找到,则将修改后的该对象的数据发送到相应应用程序客户端,保持客户端与服务器端的数据同步;
所述应用程序服务器端启动时预先把系统要处理的各种业务逻辑对象的数据从数据库中读到应用程序服务器端,并生成相应的服务器对象,每一个对象都拥有唯一的名称,在所述应用程序客户端发送到所述应用程序服务器端的请求中有一个订阅标识位,此标识位表示所述应用程序客户端是否需要对这个请求中涉及到的对象进行数据同步;若需要同步,当所述应用程序服务器端发现某个对象更新时,给订阅了这些对象同步请求的所述应用程序客户端发送更新了的对象数据;所述应用程序服务器端作为主动发起方,所述应用程序客户端定时的发送心跳包以使所述应用程序服务器知道所述应用程序客户端的活动状态。
6.如权利要求5所述的方法,其特征在于,
所述应用程序客户端信息及其订阅的对象的信息的表格,包括:应用程序客户端名称、应用程序客户端地址、应用程序客户端通信端口及其订阅的对象列表的信息;
当所述应用程序客户端需要对所述请求中涉及到的对象进行数据同步时,所述应用程序服务器端记录发送此请求的所述应用程序客户端信息,记录在所述应用程序服务器端的信息形成所述表格,所述信息包括所述应用程序客户端的IP地址、端口、订阅的对象ID号;当所述应用程序服务器端发现某个对象更新时,查找所述表格,获得订阅了这些对象同步请求的所述应用程序客户端的信息。
7.如权利要求6所述的方法,其特征在于,
还包括:所述应用程序服务器端检测对象的数据是否发生变化,若是,则根据该对象的名称在所述表格中查找订阅了该对象的应用程序客户端,判断若找到,则对更新后对象的数据进行封装后,将封装后的对象的数据根据应用程序客户端的地址和通信端口,发送到相应应用程序客户端。
8.如权利要求5所述的方法,其特征在于,
还包括:所述应用程序服务器端接收到所述业务请求后,判断如果在进行业务处理的过程中更新或删除了应用程序服务器端中的某对象,则对所述表格进行相应更新,并记录对该对象的查询、更新和删除操作。
9.如权利要求5所述的方法,其特征在于,
进一步包括:所述应用程序服务器端在启动时从数据库中读取需要的数据后,构造成各种业务逻辑对象;判断若修改了业务逻辑对象,并将修改后的数据写入数据库,以保持数据的一致性。
10.如权利要求9所述的方法,其特征在于,
进一步包括:所述应用程序服务器端监控数据库中的相应数据表,该数据表记录了由应用程序客户端直接对数据库中的基础数据进行操作后数据的变化情况,根据该变化情况更新相应的业务逻辑对象。
CN201110271644.0A 2011-09-14 2011-09-14 一种客户端与服务器端双向同步的方法及系统 Active CN102291416B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201110271644.0A CN102291416B (zh) 2011-09-14 2011-09-14 一种客户端与服务器端双向同步的方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201110271644.0A CN102291416B (zh) 2011-09-14 2011-09-14 一种客户端与服务器端双向同步的方法及系统

Publications (2)

Publication Number Publication Date
CN102291416A CN102291416A (zh) 2011-12-21
CN102291416B true CN102291416B (zh) 2015-09-30

Family

ID=45337524

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201110271644.0A Active CN102291416B (zh) 2011-09-14 2011-09-14 一种客户端与服务器端双向同步的方法及系统

Country Status (1)

Country Link
CN (1) CN102291416B (zh)

Families Citing this family (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103379115B (zh) * 2012-04-28 2018-01-05 盛乐信息技术(上海)有限公司 一种本地存储与网络存储的数据同步方法和设备
CN102722405B (zh) * 2012-06-06 2015-05-13 新浪网技术(中国)有限公司 高并发、多线程应用中的计数方法及系统
CN103051721B (zh) * 2012-12-26 2015-11-25 华为技术有限公司 一种事件通知方法及装置
CN104184756A (zh) * 2013-05-21 2014-12-03 阿里巴巴集团控股有限公司 一种数据同步方法、装置及系统
CN104462106A (zh) * 2013-09-17 2015-03-25 鸿富锦精密工业(深圳)有限公司 数据更新方法及系统
CN104618308B (zh) * 2013-11-04 2019-09-13 腾讯科技(武汉)有限公司 协议请求处理方法及装置
CN103929477B (zh) * 2014-03-31 2017-09-19 国网山东省电力公司 基于Http协议的系统间无耦合集成模拟方法及系统
CN104298750B (zh) * 2014-10-14 2018-02-23 北京国双科技有限公司 用于实时系统通信的更新处理方法及装置
US20170154066A1 (en) * 2015-11-30 2017-06-01 International Business Machines Corporation Subscription service for monitoring changes in remote content
CN106897294A (zh) * 2015-12-18 2017-06-27 鼎捷软件股份有限公司 数据同步系统与数据同步方法
KR20170110957A (ko) * 2016-03-24 2017-10-12 엘에스산전 주식회사 감시제어데이터수집시스템 및 상기 감시제어데이터수집시스템에서의 데이터엔지니어링 방법
CN107659546A (zh) * 2016-07-25 2018-02-02 武汉票据交易中心有限公司 一种基于事件的流程处理方法及装置和服务器
CN108712461B (zh) * 2018-04-04 2021-03-23 烽火通信科技股份有限公司 数据收集服务的实现系统及方法
CN110691112A (zh) * 2018-07-06 2020-01-14 优信拍(北京)信息科技有限公司 一种数据同步方法,装置及系统
CN109032747B (zh) * 2018-08-10 2021-10-15 江苏奇异点网络有限公司 数据更新方法及装置
CN109857747B (zh) * 2018-12-18 2021-07-13 百度在线网络技术(北京)有限公司 数据同步更新方法、系统和计算机设备
CN110401191B (zh) * 2019-07-29 2020-12-08 浙江大学 基于时序逻辑的电动车充电桩业务逻辑一致性分析方法
CN111177254B (zh) * 2019-12-05 2021-08-17 武汉达梦数据库股份有限公司 一种异构关系型数据库之间数据同步的方法和装置
CN112328685A (zh) * 2020-11-05 2021-02-05 浪潮云信息技术股份公司 一种全对等分布式数据库数据同步方法
CN112822036A (zh) * 2020-12-28 2021-05-18 苏宁消费金融有限公司 一种分布式系统的配置数据同步方法
CN113010602A (zh) * 2021-03-12 2021-06-22 北京三快在线科技有限公司 一种数据同步方法、装置及系统
CN113096006A (zh) * 2021-04-19 2021-07-09 上海跃影科技有限公司 一种应用于全息场景的文件同步方法和系统

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1509000A (zh) * 2002-12-15 2004-06-30 华为技术有限公司 一种网元内部实时数据的同步方法
CN101227265A (zh) * 2008-01-31 2008-07-23 深圳国人通信有限公司 一种设备监控系统中客户端之间数据同步的方法

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1509000A (zh) * 2002-12-15 2004-06-30 华为技术有限公司 一种网元内部实时数据的同步方法
CN101227265A (zh) * 2008-01-31 2008-07-23 深圳国人通信有限公司 一种设备监控系统中客户端之间数据同步的方法

Also Published As

Publication number Publication date
CN102291416A (zh) 2011-12-21

Similar Documents

Publication Publication Date Title
CN102291416B (zh) 一种客户端与服务器端双向同步的方法及系统
CN102682052B (zh) 过滤数据存储上的查询数据
US9367261B2 (en) Computer system, data management method and data management program
CN102571940B (zh) 应用程序远程安装系统、方法、智能终端、应用服务器
CN106888245B (zh) 一种数据处理方法、装置及系统
US10275347B2 (en) System, method and computer program product for managing caches
TWI671643B (zh) 配置變更方法、設備及系統
CN102360324B (zh) 故障恢复方法和用于故障恢复的设备
CN102402441B (zh) 一种对多台计算机进行配置的系统和方法
CN104065517A (zh) 分布式系统软件配置管理方法和系统
CN110795503A (zh) 分布式存储系统的多集群数据同步方法及相关装置
CN104199957A (zh) 一种Redis通用代理的实现方法
CN105472002A (zh) 基于集群节点间即时拷贝的会话同步方法
CN105653425A (zh) 基于复杂事件处理引擎的监控系统
CN108055322B (zh) 请求消息处理方法及装置
CN104572845A (zh) 文件分发方法、装置、设备及系统
CN111818117A (zh) 数据更新的方法、装置、存储介质及电子设备
CN103024065A (zh) 用于云存储系统的系统配置管理方法
CN103561095A (zh) 一种数据同步方法、节点及存储服务集群
CN102202087A (zh) 一种标识存储设备的方法及系统
JP2012234333A (ja) クラスタシステム、同期制御方法、サーバ装置および同期制御プログラム
CN105245560A (zh) 一种实现分布式缓存的方法、装置及系统
CN103716384A (zh) 跨数据中心实现云存储数据同步的方法和装置
CN111338834B (zh) 数据存储方法和装置
CN117130730A (zh) 面向联邦Kubernetes集群的元数据管理方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant