CN101840348A - 数据库中间件系统 - Google Patents

数据库中间件系统 Download PDF

Info

Publication number
CN101840348A
CN101840348A CN 200910260170 CN200910260170A CN101840348A CN 101840348 A CN101840348 A CN 101840348A CN 200910260170 CN200910260170 CN 200910260170 CN 200910260170 A CN200910260170 A CN 200910260170A CN 101840348 A CN101840348 A CN 101840348A
Authority
CN
China
Prior art keywords
database
component
external
middleware system
database middleware
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
Application number
CN 200910260170
Other languages
English (en)
Other versions
CN101840348B (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.)
SHAANXI MDC TELECOMMUNICATION CO Ltd
Original Assignee
SHAANXI MDC TELECOMMUNICATION 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 SHAANXI MDC TELECOMMUNICATION CO Ltd filed Critical SHAANXI MDC TELECOMMUNICATION CO Ltd
Priority to CN 200910260170 priority Critical patent/CN101840348B/zh
Publication of CN101840348A publication Critical patent/CN101840348A/zh
Application granted granted Critical
Publication of CN101840348B publication Critical patent/CN101840348B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

数据库中间件系统,与外部数据库连接,包括:数据处理通信组件,为外部应用程序组件提供应用程序接口以加载中间件系统,调度管理数据库中间件系统通过msip协议与外部应用程序组件通信,实现外部应用程序组件与外部数据库的通信;数据库处理组件,包括和外部数据库通信的共享数据库连接模块,及数据库操作监控器模块,检测数据库中间件系统与外部数据库之间的连接是否有效。数据库中间件系统还包括信息管理组件,其包括服务管理器模块,为不同任务设定不同处理优先级,与数据处理通信组件和数据库处理组件协调,根据设定的处理优先级并根据任务与所处的网络环境的关系,动态调度任务。

Description

数据库中间件系统
技术领域
本发明涉及通信领域,具体涉及一种用于通信行业的数据库中间件。
背景技术
目前商用的数据库如:Oracle、SQL Server、MySQL等都是使用c和c++开发的,所以它对外提供的接口基本上是c的API(应用程序接口),于是以前的数据库都是使用嵌入式的c或c++等进行访问,这就给开发系统带来了困难。后来随着数据技术的发展,数据库管理系统的厂商开始针对不同的语言提供不同语言的API,这是一个巨大的进步,但是又存在一个问题:使用不同的数据库的应用程序,不能相互移植,即各个数据库管理系统不兼容。这就给软件的开发,移植和扩展带来了很大的问题,违背了软件工程的思想。
基于上述背景,数据库中间件技术应运而生。其中最典型的当数微软的数据库中间件方案ODBC,及其扩展和发展如OLEDB、ADO以及ADO.NET和JAVA平台的JDBC技术,以及在其上所开发的更高层的中间件技术。目前主要存在以下各种技术:从最原始的GUI技术和数据库API使用,再到微软数据库中间件技术,再到JAVA平台的数据库访问技术。这些技术都存在着不同的缺点,比如,CGI程序不能被多个客户请求共享,每当接到一个客户请求,即使有一个该CGI程序的实例在运行,也必须重新启动一个相同的实例,即创建一个并发进程.并发请求越多,创建的并发进程越多,占用了大量内存,限制了应用程序自身所用的内存资源,而且每个请求创建一个进程也会消耗很多时间,在需要多个数据库连接的多用户应用中,采用CGI来连接数据库势必会随用户的增加而增加用户连接数据库的等待时间,使系统的性能降低,并可导致系统最终的崩溃。再比如,API相互之间不兼容,它们只能在特定的服务器和操作系统上运行,由于采用了动态链接库的形式,一旦代码质量较差就比较容易造成服务器系统的崩溃,并且进行程序设计时会更复杂,由于它们与具体的数据库耦合性太强,对于不同的数据库来说开发应用灵活性差,加上依赖于具体的平台和相应的数据库版本,使其移植性差,从而导致开发周期加大,可靠性难以得到保障。
发明内容
一种数据库中间件系统,其与外部数据库连接,所述数据库中间件系统包括:
数据处理通信组件,为外部应用程序组件提供应用程序接口以便加载所述中间件系统,且调度与管理所述数据库中间件系统通过msip协议与外部应用程序组件通信,从而实现所述外部应用程序组件与所述外部数据库的通信;数据库处理组件,包括1)共享数据库连接模块,其和所述外部数据库通信,以及2)数据库操作监控器模块,其检测所述数据库中间件系统与所述外部数据库之间的连接是否有效,若发现连接无效则调用所述共享数据库连接模块以实现与所述外部数据库的连接;以及信息管理组件,包括服务管理器模块,其为不同的任务设定不同的处理优先级,且与所述数据处理通信组件以及数据库处理组件相互协调,根据所设定的处理优先级,并根据任务与其所处的网络环境的相互关系,动态地调度任务;其中当收到外部应用程序组件对数据的请求时,所述数据处理通信组件与所述服务管理器模块通信,所述服务管理器模块根据所述请求,调度所述共享数据库连接模块使其提供与所述请求相应的接口,再由所述共享数据库连接模块与外部数据库进行交互数据操作,并返回操作结果。
以上概述仅为示意性的,并不意在以任何方式进行限制。除了上文所述的示意性方面、实施例和特征之外,将通过参照附图和下文的详细描述而使进一步的方面、实施例和特征变得明显。
附图说明
图1是根据本公开内容的一个实施方案的数据库中间件系统的模块架构图。
具体实施方式
在下文的详细描述中,将参照形成本说明书一部分的附图。在附图中,相似的附图标记通常指代相似的部件,除非上下文中另行指出。在详细说明书、附图和权利要求书中所描述的示意性实施例并不意在限制。在不偏离在此展现的主体的精神和范围的情况下,可以采用其他实施例,并且可以进行其他变化。易于理解的是,在此所大致描述的以及附图中所图示的本公开内容的各方面可以在宽泛的配置变化中进行排列、替换、组合、分拆和删节,所有这些均被明确考虑于此。
图1是根据本公开内容的一个实施方案的数据库中间件系统的模块架构图。在此实施方案中公开了一种数据库中间件系统100,其与外部数据库300如图中所示的Oracle数据库310、DB数据库320等连接,数据库中间件系统100包括:
数据处理通信组件101,为外部应用程序组件200诸如自动呼叫分配系统210、人工坐席系统220等提供应用程序接口以便加载数据库中间件系统100,且调度与管理数据库中间件系统100通过msip协议与外部应用程序组件200通信,从而实现外部应用程序组件200与外部数据库组件300的通信。msip协议是一种中间件与外部各应用程序通信协议,该通信协议按照通信行业特点设计,涵盖通信行业数据处理各种内容,协议可自动加载,自动升级,自动识别不同通讯版本和通讯请求。中间件系统100通过msip协议与外部应用程序组件的通信采用TCP/IP的方式进行,支持单包、多包,根据业务特点自动拆包、自动组包,支持根据业务优先级和属性保持数据零丢失、零误码。
在这个实施方案中,数据库中间件系统100还包括了数据库处理组件120,其包括1)共享数据库连接模块121,其和外部数据库300诸如Oracle数据库310、DB数据库320等通信,负责与外部数据库之间通信,接口的实现,实现中间件与各种数据库连接的物理操作;以及2)数据库操作监控器模块122,其检测数据库中间件系统100与外部数据库诸如Oracle、DB等之间的连接是否有效,若发现连接无效则调用共享数据库连接模块121以实现与外部数据库300的连接。也就是说,数据库操作监控器模块122负责调度管理中间件系统100与外部数据库300的物理连接的有效性和连接池的动态维护。
在这个实施方案中,数据库中间件系统100还包括了信息管理组件130。针对通信行业中网络环境具有异构性、动态性和分布性,数据流量大,不同业务有着等级处理区别,加之对数据实时性和准确性要求高的特点,信息管理组件130采用了业务优先动态调度自适应算法,这需要数据处理通信组件110、数据库操作监控器模块122、共享数据库连接模块121的相互协调。该算法利用业务和环境的交互模型来动态地实现网络中的任务分配。相比于现有技术的方法,该算法对于网络中的动态环境具有更好的适应性,且调度性能更优。在这个实施方案中,信息管理组件130包括例如服务管理器模块131,其为不同的任务设定不同的处理优先级,且与数据处理通信组件101以及数据库处理组件120相互协调,根据所设定的处理优先级,并根据任务与其所处的网络环境的相互关系,动态地调度任务。服务管理器模块131管理所有服务信息,协调中间件100内各个组件的调度,同时也为外部组件提供共享数据呈现,兼容各种操作系统和32位及64位系统。
当收到外部应用程序组件200对数据的请求时,所述数据处理通信组件110与服务管理器模块131通信,所述服务管理器模块根据所述请求,调度共享数据库连接模块121使其提供与所述请求相应的接口,再由共享数据库连接模块121与外部数据库300进行交互数据操作,并返回操作结果。中间件操作结果提供成功、失败、异常、多结果集、单结果集、自定义结果集等多种类型,数据类型及字段定义与数据库无关,实现了数据库切换或操作系统切换时的兼容性问题,满足通信行业操作系统种类繁多、数据库种类繁多、分布式部署、跨平台部署、异地部署等特性。
在根据本公开内容的一个实施方案中,数据库中间件系统还包括辅助功能组件140,其包括日志管理器模块141。日志管理器模块141记录数据库中间件系统100中各组件的日志信息,并读取配置文件150供数据库中间件系统100的各组件调用,例如通过全局变量142读取配置文件150。辅助功能组件140实现了配置文件信息管理、日志记录等功能,并协调中间件内其他各模块的动作,方便外部应用程序组件200对各种操作的事件和结果进行跟踪,有效的减低排查问题的时间周期。在此实施方案中,对外部数据库300相关的信息进行的修改均通过调用配置文件150而实现,所述修改可包括对数据请求的增加和减少,还可包括对数据字段的名称、属性、长度以及内容的修改。任何改动无需修改中间件程序和业务层程序(外部应用程序组件)。
根据本发明的实施方案的数据库中间件系统,所有与外部数据库有关的操作都集成在该中间件,部署时用一个应用程序加载该中间件系统作为服务端,而外部组件只需要遵循msip协议规范通过加载了该中间件的应用程序即可实现与数据库的信息交互,从而可实现不同数据库间快速切换,且数据库切换时无需增加额外数据库授权,整体平台业务层即外部应用程序组件不需做任何调整,大大降低了大容量、高可靠性系统的开发周期。根据本发明的实施方案的数据库中间件系统适合通信行业中不同规模的公司,适于被不同业务特点、不同容量的系统使用,且在系统用户数变化、系统容量、性能有所调整后,能适应系统调整前后的多种操作系统或数据库的性能要求。在满足以上需求的同时,根据本发明的实施方案的数据库中间件系统与现有的各种中间件相比较又无需安装多种数据引擎系统包,软件绿色,易加载使用,且经过了上千万用户级大系统长期无间断运行的考验。
虽然已结合优选实施方案和特定实施例描述了本公开内容,但并不意味着本公开内容的范围仅限于所阐述的特定实施方案,因为此处的实施方案在所有方面均为描述目的而不为限制目的。对本领域技术人员而言,显然可以对本公开内容作出修改和变更而不脱离其范围和精神。此处的说明和实施例仅为举例,而本公开内容的真正范围和精神将由下面的权利要求书表示。

Claims (4)

1.一种数据库中间件系统,其与外部数据库连接,所述数据库中间件系统包括:
数据处理通信组件,为外部应用程序组件提供应用程序接口以便加载所述中间件系统,且调度与管理所述数据库中间件系统通过msip协议与外部应用程序组件通信,从而实现所述外部应用程序组件与所述外部数据库的通信;
数据库处理组件,包括
1)共享数据库连接模块,其和所述外部数据库通信,以及
2)数据库操作监控器模块,其检测所述数据库中间件系统与所述外部数据库之间的连接是否有效,若发现连接无效则调用所述共享数据库连接模块以实现与所述外部数据库的连接;
以及
信息管理组件,包括服务管理器模块,其为不同的任务设定不同的处理优先级,且与所述数据处理通信组件以及数据库处理组件相互协调,根据所设定的处理优先级,并根据任务与其所处的网络环境的相互关系,动态地调度任务;
其中当收到外部应用程序组件对数据的请求时,所述数据处理通信组件与所述服务管理器模块通信,所述服务管理器模块根据所述请求,调度所述共享数据库连接模块使其提供与所述请求相应的接口,再由所述共享数据库连接模块与外部数据库进行交互数据操作,并返回操作结果。
2.根据权利要求1所述的数据库中间件系统,其中所述数据库中间件系统还包括辅助功能组件,其包括
日志管理器模块,其记录所述数据库中间件系统各组件的日志信息,并读取配置文件供所述数据库中间件系统各组件调用。
3.根据权利要求2所述的数据库中间件系统,其中对与所述外部数据库相关的信息进行的修改均通过调用所述配置文件而实现。
4.根据权利要求3所述的数据库中间件系统,其中对与所述外部数据库相关的信息进行的修改包括了对数据请求的增加和减少,以及对数据字段的名称、属性、长度以及内容的修改。
CN 200910260170 2009-12-24 2009-12-24 数据库中间件系统 Active CN101840348B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN 200910260170 CN101840348B (zh) 2009-12-24 2009-12-24 数据库中间件系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN 200910260170 CN101840348B (zh) 2009-12-24 2009-12-24 数据库中间件系统

Publications (2)

Publication Number Publication Date
CN101840348A true CN101840348A (zh) 2010-09-22
CN101840348B CN101840348B (zh) 2013-02-20

Family

ID=42743734

Family Applications (1)

Application Number Title Priority Date Filing Date
CN 200910260170 Active CN101840348B (zh) 2009-12-24 2009-12-24 数据库中间件系统

Country Status (1)

Country Link
CN (1) CN101840348B (zh)

Cited By (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101969399A (zh) * 2010-09-30 2011-02-09 北京神州泰岳软件股份有限公司 客户端调用服务的路由方法及系统
CN102243653A (zh) * 2011-06-16 2011-11-16 苏州阔地网络科技有限公司 一种数据库连接的管理方法及装置
CN102243655A (zh) * 2011-06-16 2011-11-16 苏州阔地网络科技有限公司 一种数据库的连接管理方法及装置
CN102262561A (zh) * 2011-07-01 2011-11-30 深圳市极限网络科技有限公司 数据库大批量任务处理的调度方法
CN102438030A (zh) * 2010-09-29 2012-05-02 新奥特(北京)视频技术有限公司 一种适用于广电云架构平台的打包系统及方法
CN103607376A (zh) * 2013-10-29 2014-02-26 北京奇虎科技有限公司 一种兼容协议的方法及装置
CN104462200A (zh) * 2014-10-31 2015-03-25 北京思特奇信息技术股份有限公司 一种通过第三方数据库控制系统切换的方法及系统
CN104503989A (zh) * 2014-12-03 2015-04-08 中建材国际贸易有限公司 一种完成异构数据库归集的方法
CN105786998A (zh) * 2016-02-19 2016-07-20 创元网络技术股份有限公司 数据库中间件系统及利用其处理数据的方法
CN106484824A (zh) * 2016-09-28 2017-03-08 华东师范大学 基于多元数据库支持组件的知识图谱异构存储框架中间件
CN106503087A (zh) * 2016-10-12 2017-03-15 郑州云海信息技术有限公司 一种用于分布式数据访问的数据库中间件
CN106909563A (zh) * 2015-12-23 2017-06-30 上海热璞网络科技有限公司 一种分布式系统
CN108052673A (zh) * 2017-12-29 2018-05-18 中国电子科技集团公司信息科学研究院 一种物联网数据集成与融合中间件系统
CN108415909A (zh) * 2017-02-09 2018-08-17 北京京东尚科信息技术有限公司 一种访问不同数据库的系统及方法
CN108932309A (zh) * 2018-06-15 2018-12-04 上海陆家嘴国际金融资产交易市场股份有限公司 跨平台数据库管理方法、装置、计算机设备和存储介质
CN109960709A (zh) * 2019-04-18 2019-07-02 上海达梦数据库有限公司 一种数据库驱动的处理方法、装置、设备及存储介质
CN110018916A (zh) * 2019-04-10 2019-07-16 福州大学 一种通信任务可组态功能的实现方法
CN110059111A (zh) * 2019-04-17 2019-07-26 珠海金山网络游戏科技有限公司 一种数据调用方法、装置、一种计算设备及存储介质
CN111930445A (zh) * 2020-06-28 2020-11-13 航天信息股份有限公司 一种支持主流浏览器对组件的调用方法

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6167405A (en) * 1998-04-27 2000-12-26 Bull Hn Information Systems Inc. Method and apparatus for automatically populating a data warehouse system
CN1351299A (zh) * 2000-10-28 2002-05-29 深圳市中兴通讯股份有限公司 一种访问数据库的方法及装置
CN100377156C (zh) * 2005-03-08 2008-03-26 中国科学院计算技术研究所 一种利用组通信系统进行数据库复制的方法和中间件

Cited By (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102438030A (zh) * 2010-09-29 2012-05-02 新奥特(北京)视频技术有限公司 一种适用于广电云架构平台的打包系统及方法
CN101969399B (zh) * 2010-09-30 2012-10-10 北京神州泰岳软件股份有限公司 客户端调用服务的路由方法及系统
CN101969399A (zh) * 2010-09-30 2011-02-09 北京神州泰岳软件股份有限公司 客户端调用服务的路由方法及系统
CN102243653A (zh) * 2011-06-16 2011-11-16 苏州阔地网络科技有限公司 一种数据库连接的管理方法及装置
CN102243655A (zh) * 2011-06-16 2011-11-16 苏州阔地网络科技有限公司 一种数据库的连接管理方法及装置
CN102243655B (zh) * 2011-06-16 2012-07-18 苏州阔地网络科技有限公司 一种数据库的连接管理方法及装置
CN102262561B (zh) * 2011-07-01 2016-06-01 深圳市极限网络科技有限公司 数据库大批量任务处理的调度方法
CN102262561A (zh) * 2011-07-01 2011-11-30 深圳市极限网络科技有限公司 数据库大批量任务处理的调度方法
CN103607376B (zh) * 2013-10-29 2017-01-11 北京奇虎科技有限公司 一种兼容协议的方法及装置
CN103607376A (zh) * 2013-10-29 2014-02-26 北京奇虎科技有限公司 一种兼容协议的方法及装置
CN104462200A (zh) * 2014-10-31 2015-03-25 北京思特奇信息技术股份有限公司 一种通过第三方数据库控制系统切换的方法及系统
CN104503989A (zh) * 2014-12-03 2015-04-08 中建材国际贸易有限公司 一种完成异构数据库归集的方法
CN104503989B (zh) * 2014-12-03 2019-04-19 中建材国际贸易有限公司 一种完成异构数据库归集的方法
CN106909563A (zh) * 2015-12-23 2017-06-30 上海热璞网络科技有限公司 一种分布式系统
CN106909563B (zh) * 2015-12-23 2021-01-08 上海热璞网络科技有限公司 一种分布式系统
CN105786998A (zh) * 2016-02-19 2016-07-20 创元网络技术股份有限公司 数据库中间件系统及利用其处理数据的方法
CN105786998B (zh) * 2016-02-19 2019-02-26 创元网络技术股份有限公司 数据库中间件系统及利用其处理数据的方法
CN106484824A (zh) * 2016-09-28 2017-03-08 华东师范大学 基于多元数据库支持组件的知识图谱异构存储框架中间件
CN106484824B (zh) * 2016-09-28 2019-09-10 华东师范大学 基于多元数据库支持组件的知识图谱异构存储框架中间件
CN106503087A (zh) * 2016-10-12 2017-03-15 郑州云海信息技术有限公司 一种用于分布式数据访问的数据库中间件
CN108415909A (zh) * 2017-02-09 2018-08-17 北京京东尚科信息技术有限公司 一种访问不同数据库的系统及方法
CN108052673A (zh) * 2017-12-29 2018-05-18 中国电子科技集团公司信息科学研究院 一种物联网数据集成与融合中间件系统
CN108932309A (zh) * 2018-06-15 2018-12-04 上海陆家嘴国际金融资产交易市场股份有限公司 跨平台数据库管理方法、装置、计算机设备和存储介质
CN110018916A (zh) * 2019-04-10 2019-07-16 福州大学 一种通信任务可组态功能的实现方法
CN110018916B (zh) * 2019-04-10 2022-10-21 福州大学 一种通信任务可组态功能的实现方法
CN110059111A (zh) * 2019-04-17 2019-07-26 珠海金山网络游戏科技有限公司 一种数据调用方法、装置、一种计算设备及存储介质
CN110059111B (zh) * 2019-04-17 2022-02-01 珠海金山网络游戏科技有限公司 一种数据调用方法、装置、一种计算设备及存储介质
CN109960709A (zh) * 2019-04-18 2019-07-02 上海达梦数据库有限公司 一种数据库驱动的处理方法、装置、设备及存储介质
CN109960709B (zh) * 2019-04-18 2021-02-05 上海达梦数据库有限公司 一种数据库驱动的处理方法、装置、设备及存储介质
CN111930445A (zh) * 2020-06-28 2020-11-13 航天信息股份有限公司 一种支持主流浏览器对组件的调用方法

Also Published As

Publication number Publication date
CN101840348B (zh) 2013-02-20

Similar Documents

Publication Publication Date Title
CN101840348B (zh) 数据库中间件系统
CN108234670B (zh) 一种基于zookeeper和netty的分布式远程调用方法
CN101631033B (zh) 远程组件的调用方法和系统、以及服务器、客户端
EP1438672B1 (en) Method, apparatus and system for a mobile web client
CN101090401B (zh) 一种群集环境下的数据缓存方法及系统
CN103491111B (zh) 无线应用发布、实现方法与装置
CN102694866B (zh) 一种分布式网络环境中的服务请求代理系统
CN102567399B (zh) 一种访问数据库的方法和装置
CN105278996A (zh) 一种日志采集方法、装置及日志服务系统
CN1969280A (zh) 使用命令行环境的远程系统管理
CN110175163A (zh) 基于业务功能智能解析的多库分离方法、系统及介质
CN102014282A (zh) 一种分布式视频转码调度方法及系统
US20020199171A1 (en) Generic Java rule engine framework
CN101562606A (zh) 开放式数据调用系统及方法
CN102937964A (zh) 基于分布式系统的智能数据服务方法
CN103677975A (zh) 一种访问应用系统内部对象的系统和方法
CN103152433A (zh) 一种分布式服务端框架及其使用、交互、请求处理方法
CN101493775A (zh) 嵌入式系统的动态加载系统及其加载方法
CN105988928B (zh) 终端应用的测试方法及移动终端
CN101499931A (zh) 基于分布式环境的功能扩展方法和系统
US11397564B2 (en) Machine learning model representation and execution
CN103186386A (zh) 应用加载方法及系统
CN102945264A (zh) 智能启用分布式事务的方法
CN102087592B (zh) 用于执行机器人应用程序的终端装置
CN101471955A (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