CN101951382B - 一种基于三层架构的数据传输系统及数据传输方法 - Google Patents
一种基于三层架构的数据传输系统及数据传输方法 Download PDFInfo
- Publication number
- CN101951382B CN101951382B CN 201010296179 CN201010296179A CN101951382B CN 101951382 B CN101951382 B CN 101951382B CN 201010296179 CN201010296179 CN 201010296179 CN 201010296179 A CN201010296179 A CN 201010296179A CN 101951382 B CN101951382 B CN 101951382B
- Authority
- CN
- China
- Prior art keywords
- client
- data
- data processing
- layer
- 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
Links
Images
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明公开了使用基于三层架构的数据传输系统进行数据传输的方法,包括:第一层包括若干个客户端,第二层包括若干个数据处理服务器,第三层包括数据库服务器;每个所述数据处理服务器与至少一个所述客户端连接,用于收集所述客户端的工作状态以及处理所述客户端的交易数据,并将处理后的交易数据上传至所述数据库服务器;以及从所述数据库服务器读取所述交易数据发送至所连接的所述客户端;所述数据库服务器与各所述数据处理服务器连接,用于存储交易数据。
Description
技术领域
本发明涉及数据传输领域,尤其涉及一种使用基于三层架构的数据传输系统进行数据传输的方法。
背景技术
现行业应用软件大部分是基于关系式数据库的信息处理系统,即MIS系统;软件的系统架构上从两层的C/S结构(客户端/服务器结构),发展到B/S结构(浏览器/服务器);由于现能开发三层结构的数据传输系统的公司少,其次国内对三层结构的数据传输的认识不足,所以现在零售行业内应用最多的是两层C/S结构,或B/S结构。
在此以连锁零售行业的业务管理系统为例,品牌连锁零售业企业通常在全国各省、市、区都拥有自己的店铺,每间店铺有一台或者上百、上千台收银系统,随着经营规模的日益扩展,总部对店铺的管理业务越来越繁重,大量的数据传输、上万的货品信息、库存信息、上十万的会员群体,加上各区域成本的差异、价格的差异令数据的汇总和计算量成几何级数增加。数据量庞大,对现有的基于两层C/S结构,或B/S结构的数据传输系统,难于实现数据从集中到分布过渡到从分布到集中的数据管理,不利于业务的线性扩展。
现有技术中有一种采用基于4层构架的数据处理系统并使用硬件方式来实现,即在界面层和业务处理层之间增加一层数据转发层,数据转发层由路由器组成(具体请参考申请号为200410078182.0的中国专利申请),数据转发层用于连接后台服务子系统和客户端,根据数据属性,将客户端与相应后台子服务系统的应用服务器相匹配,建立数据交互通道,实现数据从集中到分布和从分布到集中的数据管理,但当转发系统中的某个路由器停止工作时,会使对应的客户端业务瘫痪。
发明内容
本发明提供一种使用基于三层架构的数据传输系统进行数据传输的方法,平滑地实现数据从集中到分布和从分布到集中的数据管理,实现系统性能的线性扩张。
本发明公开了一种使用基于三层架构的数据传输系统进行数据传输的方法,其特征在于,第一层包括若干个客户端,第二层包括若干个数据处理服务器,第三层包括数据库服务器;
每个所述数据处理服务器与至少一个所述客户端连接,用于收集该客户端的工作状态以及处理所述客户端的交易数据,并将处理后的交易数据上传至所述数据库服务器;以及从所述数据库服务器读取所述交易数据发送至所连接的所述客户端;
所述数据库服务器与各所述数据处理服务器连接,用于存储交易数据;
所述方法包括步骤:
所述第一层的客户端与所述第二层的数据处理服务器建立连接;
所述第二层的数据处理服务器收集所述第一层的客户端的工作状态以及处理所述第一层的客户端的交易数据,并将处理后的交易数据上传至所述第三层的数据库服务器,以及从所述第三层的数据库服务器读取所述交易数据并将其发送至所述第一层的客户端;
当第二层的一个数据处理服务器启动后,将自身的IP地址和通讯端口号通知该层的其他所述数据处理服务器;
其中,所述第一层的客户端与所述第二层的数据处理服务器建立连接的步骤具体包括:
当第一层的客户端连接第二层的其中一台所述数据处理服务器时,从所连接的该数据处理服务器获取该层的各所述数据处理服务器的IP地址和端口号,根据预先定义的连接顺序选择当前连接的所述数据处理服务器。
本发明使用软件设计若干个数据处理服务器来完成数据的收集、数据的处理、数据的上传下载,通过收集客户端的工作状态会获取到是否有数据交易等信息进而处理相应的数据,并上传到数据库服务器存储,实现数据的集中管理;根据客户端需要,将所需数据从数据库服务器下载到各客户端,实现数据的分布管理。
附图说明
图1是本发明基于三层架构的数据传输系统框图;
图2是本发明基于三层架构的数据传输系统的一个实施例示意图;
图3是本发明基于三层架构的数据传输方法的一个流程图;
图4是本发明的一个具体应用例示意图。
具体实施方式
如图1所示,这里的三层是逻辑上的三层,第一层包括若干个客户端,第二层包括若干个数据处理服务器,第三层包括若干数据库服务器;
每个数据处理服务器与至少一个客户端连接,用于收集该客户端的工作状态以及处理客户端的交易数据;
数据处理服务器将处理后的交易数据上传至数据库服务器;
数据处理服务器从数据库服务器读取交易数据发送至所连接的客户端;数据库服务器与各数据处理服务器连接,用于存储交易数据。
本发明使用软件设计若干个数据处理服务器来完成数据的收集、数据的处理、数据的上传下载和,通过收集客户端的工作状态会获取到是否有数据交易等信息进而处理相应的数据,并上传到数据库服务器存储,实现数据的集中管理;根据客户端需要,将所需数据从数据库服务器下载到各客户端,实现数据的分布管理。
下面是本发明的一个实施例,如图2,有三套数据处理服务器:数据处理服务器204、数据处理服务器205和数据处理服务器206,他们分别安装在不同的硬件服务器上(比如:计算机),为方便说明用A、B、C分别代表数据处理服务器204、数据处理服务器205和数据处理服务器206。A所在的硬件服务器的IP地址是:192.168.0.1,A的端口号是001;B所在的硬件服务器的IP地址是192.168.0.2,B的端口号是002;C所在的硬件服务器的IP地址是192.168.0.3,C的端口号是003;当系统启动A、B、C这三套数据处理服务器后,他们会将自己所在的IP地址和自身的端口号通知对方,例如:A将其所在的IP地址192.168.0.1和自身端口号001通知B和C;B将其所在的IP地址192.168.0.2和自身端口号002通知A和C;C将其所在的IP地址192.168.0.3和自身端口号003通知B和A;
同时还有3个客户端:客户端201、客户端202和客户端203;客户端可以定义连接A、B、C的顺序,客户端201的定义的连接顺序为:A→B→C;客户端202的定义的连接顺序为:B→A→C;客户端203的定义的连接顺序为:A→C→B;他们将各自定义的连接顺序存储起来。当系统启动后,客户端连接数据处理服务器时,客户端会根据自身定义的连接顺序连接:对于客户端201来说,若与A连接不成功,则会自动与B连接;若与B也连接不成功,则会与C连接。
在本发明实施例中,客户端通过预先存储与数据处理服务器的连接顺序,可以自定义先与哪个数据处理服务器连接,当与第一顺位的连接不成功时,自动连接第二顺位的数据处理服务器。
本发明的另一个实施例,同样参考图2,有三套数据处理服务器:数据处理服务器204、数据处理服务器205和数据处理服务器206,他们分别安装在不同的硬件服务器上(比如:计算机),为方便说明用A、B、C分别代表数据处理服务器204、数据处理服务器205和数据处理服务器206。数据处理服务器由监控服务模块、通讯服务模块、交易数据处理服务模块、成本计算服务模块和库存计算服务模块五个子模块组成,各个子模块有自己对应的端口号。每个客户端都有对应的唯一的ID(Identity,身份标识号码)。系统启动后,若A与客户端201连接,B与客户端202连接,C与客户端203连接,他们之间采用Socket方式通讯,支持任意组网。A、B、C将其自身的服务信息(如:服务名称和数据处理服务器的端口号等等)和各自连接的客户端的唯一的ID上传到数据库服务器,某一时刻,客户端201的工作已经完成不需要连接A,自行切断与A的连接,A会将这断开连接的信息(如:客户端ID、A的端口号和断开连接时间等等)上传到数据库服务器,此时A作为后备数据处理服务器,扫描数据库服务器。由于某种原因,B不能正常工作,A扫描数据库服务器发现客户端202对应的服务中断,A会立即启动,与客户端202建立连接,继续提供服务。收集客户端202的工作状态(例如:是否在线、是否已更新最新数据和是否产生交易数据等等)和处理客户端202的交易数据,并上传到数据库服务器。若A发现客户端202没有更新最新数据,将从数据库服务器下载最新的数据到客户端202。
本发明实施例中,数据处理服务器会根据扫描数据库服务器的结果来启动对应的服务,当有数据处理服务器停止工作后,会启动另外一套来保证系统的稳定性。
下面介绍使用本发明公开的数据传输系统进行数据传输的方法,参考图3,步骤如下:
301、第一层客户端与第二层的数据处理服务器建立连接;
302、第二层的数据处理服务器收集第一层客户端的工作状态以及处理第一层客户端的交易数据;
303、将处理后的交易数据上传至第三层的数据库服务器;
304、从第三层的数据库服务器读取交易数据发送至第一层的客户端。
上述方法还可以包括步骤:第一层客户端连接第二层的其中一台处理服务器时,从所连接的该处理服务器获取该层的各处理服务器的IP地址和端口号,根据预先定义的连接顺序选择当前连接的处理服务器。
客户端通过预先存储与数据处理服务器的连接顺序,可以自定义先与哪个数据处理服务器连接,当与第一顺位的连接不成功时,自动连接第二顺位的数据处理服务器。
此外,还可以包括步骤:第二层的数据处理服务器启动后将自身的服务信息以及所连接的客户端的ID存入数据库服务器;第二层的其他数据处理服务器扫描数据库服务器,当在数据库服务器中未找到自身的服务信息时进行启动。
客户端的工作状态可以包括是否在线、是否已更新最新数据和是否产生交易数据等等。
数据处理服务器会根据扫描数据库服务器的结果来启动对应的服务,当有数据处理服务器停止工作后,会启动另外一套来保证系统的稳定性。
下面是本发明的具体应用例,请参考图4,这是一个零售行业的业务管理系统框图,本应用例分为4级,第一级由若干收银机组成,收银机包括:收银机401、收银机402、收银机403和收银机404;第二级由店铺数据库406店铺数据库408、数据处理服务器407和数据处理服务器405组成;第三级由区域数据库401和数据处理服务器409组成;第四级由公司总部数据库412和数据处理服务器411组成。
收银机401和收银机402把商品类别、商品价格等信息通过数据处理服务器405上传至店铺数据库406;收银机403和收银机404把商品类别、商品价格等信息通过数据处理服务器407上传至店铺数据库408;店铺数据库406和店铺数据库408通过数据处理服务器409把相应的数据信息上传至第三级的区域数据库410;区域数据库410通过数据处理服务器411把相应的数据信息上传至总部数据库412,由总部集中管理。
当有新商品上架或者原有商品价格改变,把相应的信息录入总部数据库412中,再把这些数据信息更新到区域数据库410,进而更新到下一级的店铺数据库406和店铺数据库408,再由店铺数据库更新到各收银机。收银机也可以直接在总部数据库中查询商品价格等相关信息。
以上的本发明实施方式,并不构成对本发明保护范围的限定。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明的权利要求保护范围之内。
Claims (2)
1.一种使用基于三层架构的数据传输系统进行数据传输的方法,其特征在于,所述基于三层架构的数据传输系统中的第一层包括若干个客户端,第二层包括若干个数据处理服务器,第三层包括数据库服务器;
每个所述数据处理服务器与至少一个所述客户端连接,用于收集所述客户端的工作状态、以及处理所述客户端的交易数据,并将处理后的交易数据上传至所述数据库服务器;以及从所述数据库服务器读取所述交易数据并将其发送至所连接的所述客户端;
所述数据库服务器与各所述数据处理服务器连接,用于存储交易数据;
所述方法包括步骤:
所述第一层的客户端与所述第二层的数据处理服务器建立连接;
所述第二层的数据处理服务器收集所述第一层的客户端的工作状态以及处理所述第一层的客户端的交易数据,并将处理后的交易数据上传至所述第三层的数据库服务器,以及从所述第三层的数据库服务器读取所述交易数据并将其发送至所述第一层的客户端;
当第二层的一个数据处理服务器启动后,将自身的IP地址和通讯端口号通知该层的其他所述数据处理服务器;
其中,所述第一层的客户端与所述第二层的数据处理服务器建立连接的步骤具体包括:
当第一层的客户端连接第二层的其中一台所述数据处理服务器时,从所连接的该数据处理服务器获取该层的各所述数据处理服务器的IP地址和端口号,根据预先定义的连接顺序选择当前连接的所述数据处理服务器。
2.根据权利要求1所述的方法,其特征在于,还包括步骤:
所述第二层的数据处理服务器启动后将自身的服务信息以及所连接的客户端的ID存入所述数据库服务器;
第二层的其他数据处理服务器扫描所述数据库服务器,当在所述数据库服务器中未找到自身的服务信息时进行启动。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201010296179 CN101951382B (zh) | 2010-09-28 | 2010-09-28 | 一种基于三层架构的数据传输系统及数据传输方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201010296179 CN101951382B (zh) | 2010-09-28 | 2010-09-28 | 一种基于三层架构的数据传输系统及数据传输方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN101951382A CN101951382A (zh) | 2011-01-19 |
CN101951382B true CN101951382B (zh) | 2013-06-19 |
Family
ID=43454743
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN 201010296179 Active CN101951382B (zh) | 2010-09-28 | 2010-09-28 | 一种基于三层架构的数据传输系统及数据传输方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN101951382B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106992999B (zh) * | 2017-05-26 | 2020-11-20 | 河南职业技术学院 | 一种跨服务器数据通讯处理方法 |
CN111782017A (zh) * | 2020-08-01 | 2020-10-16 | 三亚三力源生态农业有限公司 | 供应商终端数据分析系统 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1426006A (zh) * | 2001-12-21 | 2003-06-25 | 鸿富锦精密工业(深圳)有限公司 | 分布式案件管理系统及其方法 |
CN1588921A (zh) * | 2004-09-17 | 2005-03-02 | 杭州恒生电子股份有限公司 | 基于多层架构的数据处理系统及数据处理方法 |
CN201893809U (zh) * | 2010-09-28 | 2011-07-06 | 广州市科传计算机科技股份有限公司 | 一种基于三层架构的数据传输系统 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8418174B2 (en) * | 2008-02-14 | 2013-04-09 | International Business Machines Corporation | Enhancing the scalability of network caching capability in virtualized environment |
-
2010
- 2010-09-28 CN CN 201010296179 patent/CN101951382B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1426006A (zh) * | 2001-12-21 | 2003-06-25 | 鸿富锦精密工业(深圳)有限公司 | 分布式案件管理系统及其方法 |
CN1588921A (zh) * | 2004-09-17 | 2005-03-02 | 杭州恒生电子股份有限公司 | 基于多层架构的数据处理系统及数据处理方法 |
CN201893809U (zh) * | 2010-09-28 | 2011-07-06 | 广州市科传计算机科技股份有限公司 | 一种基于三层架构的数据传输系统 |
Also Published As
Publication number | Publication date |
---|---|
CN101951382A (zh) | 2011-01-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN101729412B (zh) | 地理信息服务的分布式层次集群方法和系统 | |
CN105740337B (zh) | 一种基于内容的发布订阅系统中的事件快速匹配方法 | |
CN107395729A (zh) | 一种消息队列的消费系统、方法及装置 | |
CN103262498B (zh) | 用于发布及预订环境中服务器连接优化的方法和系统 | |
CN101853437A (zh) | 端对端业务流程管理、业务事件管理和/或业务活动监控的系统和/或方法 | |
CN103761309A (zh) | 一种运营数据处理方法及系统 | |
US20060059262A1 (en) | Methods, systems and computer program products for inventory reconciliation | |
CN102646230A (zh) | 一种实现配电网故障快速复电管理的信息系统 | |
CN109102273B (zh) | 一种分布式智能支付路由的实现方法及系统 | |
CN103095498B (zh) | 话单采集方法和系统 | |
CN102185875A (zh) | 一种信息同步更新的方法与系统 | |
CN103530809A (zh) | 基于无线数字终端的机加在制品零件实时监控系统及方法 | |
CN110290168A (zh) | 数据发送方法、装置、服务器及存储介质 | |
CN114401284A (zh) | 固定污染源治理工况实时数据采集与传输系统及方法 | |
CN101951382B (zh) | 一种基于三层架构的数据传输系统及数据传输方法 | |
CN102158426A (zh) | 一种使用无线通信的社交网络服务导航方法及其系统 | |
CN105160540A (zh) | 一种基于线上到线下的服务推广系统和方法 | |
CN102340791A (zh) | 一种用于实现数据一致性的系统和方法 | |
US8595337B2 (en) | Computer link method and computer system | |
CN201893809U (zh) | 一种基于三层架构的数据传输系统 | |
CN201286116Y (zh) | 业务处理设备及业务处理系统 | |
CN108492435A (zh) | 一种电信营业厅分布式排队叫号管理系统 | |
CN105376155B (zh) | 一种基于分布式集群架构的智能路由系统及方法 | |
CN109412940B (zh) | 路由器管理方法及路由器管理系统 | |
CN104135714A (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 | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant |