CN115292100A - 数据库故障处理方法、装置、电子设备及存储介质 - Google Patents

数据库故障处理方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN115292100A
CN115292100A CN202210996686.9A CN202210996686A CN115292100A CN 115292100 A CN115292100 A CN 115292100A CN 202210996686 A CN202210996686 A CN 202210996686A CN 115292100 A CN115292100 A CN 115292100A
Authority
CN
China
Prior art keywords
middleware
database
information
transaction
fault
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.)
Pending
Application number
CN202210996686.9A
Other languages
English (en)
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.)
Industrial and Commercial Bank of China Ltd ICBC
Original Assignee
Industrial and Commercial Bank of China Ltd ICBC
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 Industrial and Commercial Bank of China Ltd ICBC filed Critical Industrial and Commercial Bank of China Ltd ICBC
Priority to CN202210996686.9A priority Critical patent/CN115292100A/zh
Publication of CN115292100A publication Critical patent/CN115292100A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/16Error detection or correction of the data by redundancy in hardware
    • G06F11/20Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements
    • G06F11/202Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where processing functionality is redundant
    • G06F11/2023Failover techniques
    • G06F11/203Failover techniques using migration
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/21Design, administration or maintenance of databases
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/546Message passing systems or structures, e.g. queues
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/54Indexing scheme relating to G06F9/54
    • G06F2209/547Messaging middleware

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Databases & Information Systems (AREA)
  • Quality & Reliability (AREA)
  • Data Mining & Analysis (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本公开提供了一种数据库故障处理方法、装置、电子设备及存储介质,可以应用于计算机技术领域。该数据库故障处理方法包括:从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;将交易业务的交易信息传输至第二中间件;以及基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库。

Description

数据库故障处理方法、装置、电子设备及存储介质
技术领域
本公开涉及计算机技术领域,更具体地,涉及一种数据库故障处理方法、装置、电子设备、存储介质及计算机程序产品。
背景技术
国际商业机器(International Business Machines Corporation,IBM)大型机联机系统由多个逻辑分区(Logical Partitions,LPAR)组成,每个LPAR运行多个主机事务处理系统(Custom Information Control System,CICS,简称中间件)和DB2 Member(DataBase2 Member,IBM大型机数据库的子数据库),多个DB2 Member组成一个主机数据库(简称DB2),读写同一套磁盘数据。IBM大型机的CICS通过DB2连接资源(DB2 Connection)来访问与CICS对应的DB2 Member。
在实现本公开构思的过程中,发明人发现相关技术中至少存在如下问题:相关技术中,对例如在IBM大型机联机系统出现数据库故障的情况下,会影响大型机的前端业务服务水平。
发明内容
有鉴于此,本公开提供了一种数据库故障处理方法、装置、电子设备、存储介质及计算机程序产品。
本公开的一个方面提供了一种数据库故障处理方法,包括:
从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;
基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;
将交易业务的交易信息传输至第二中间件;以及
基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库。
根据本公开的实施例,上述数据库故障处理方法还包括:
标记第一数据库为故障恢复状态;以及
对第一数据库进行自动恢复。
根据本公开的实施例,上述数据库故障处理方法还包括:
从预定的数据库列表中确定运行正常的第三数据库,其中,预定的数据库列表用于表征联机系统中的逻辑分区和数据库之间的对应关系,第三数据库和第一数据库分别与联机系统中的同一逻辑分区相对应;以及
将第一中间件与第一数据库的映射关系替换为第一中间件与第三数据库的映射关系。
根据本公开的实施例,其中,从第一中间件中获取业务异常信息,包括:
在交易业务存在异常的情况下,接收来自第一中间件的故障报警;以及
基于故障报警,从第一中间件中获取业务异常信息,其中,业务异常信息包括以下至少一项:与交易业务相关的请求信息、与交易业务相关的通信信息、与故障相关的标识信息。
根据本公开的实施例,其中,在交易业务存在异常的情况下,接收来自第一中间件的故障报警,包括:
在交易业务存在异常的情况下,利用故障捕获模块获取来自第一中间件的故障报警,其中,故障捕获模块装载于第一中间件中,故障捕获模块用于对故障进行实时监控。
根据本公开的实施例,其中,基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障,包括:
基于业务异常信息,确定与业务异常信息相匹配的故障解析信息;以及
基于故障解析信息,确定与第一中间件相匹配的第一数据库存在故障。
根据本公开的实施例,上述数据库故障处理方法还包括:
基于业务异常信息,对交易业务进行回滚处理;以及
停止利用第一中间件处理交易业务。
根据本公开的实施例,其中,将交易业务的交易信息传输至第二中间件,包括:
从预定的中间件列表中确定运行正常的第二中间件,其中,预定的中间件列表用于表征联机系统中的逻辑分区和中间件之间的对应关系,第一中间件和第二中间件分别与联机系统中的同一逻辑分区相对应;以及
将交易业务的交易信息传输至第二中间件。
本公开的另一个方面提供了一种数据库故障处理装置,包括:
获取模块,用于从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;
确定模块,用于基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;
传输模块,用于将交易业务的交易信息传输至第二中间件;以及
访问模块,用于基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库。
本公开的另一方面提供了电子设备,包括:一个或多个处理器;存储器,用于存储一个或多个指令,其中,当一个或多个指令被一个或多个处理器执行时,使得一个或多个处理器实现如上所述的方法。
本公开的另一方面提供了一种计算机可读存储介质,存储有计算机可执行指令,指令被处理器执行时使处理器实现如上所述的方法。
本公开的另一方面提供了一种计算机程序产品,计算机程序产品包括计算机可执行指令,指令在被执行时用于实现如上所述的方法。
根据本公开的实施例,采用了从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;将交易业务的交易信息传输至第二中间件;以及基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库的技术手段,使得根据业务异常信息,可以确定第一数据库存在异常,并将交易信息传输至第二中间件,利用第二中间件访问没有出现异常的第二数据库,从而使得交易业务可以在第二中间件进行处理,不会影响交易业务的处理过程,由此使得前端的用户感觉不到,所以至少部分地克服了相关技术中,对例如在IBM大型机联机系统出现数据库故障的情况下,会影响大型机的前端业务服务水平的技术问题。
附图说明
通过以下参照附图对本公开实施例的描述,本公开的上述以及其他目的、特征和优点将更为清楚,在附图中:
图1示意性示出了相关技术中的大型机联机系统的架构图;
图2示意性示出了根据本公开实施例的可以应用数据库故障处理方法的示例性系统架构;
图3示意性示出了根据本公开实施例的数据库故障处理方法的流程图;
图4示意性示出了根据本公开实施例的可以应用数据库故障处理方法的系统框图;
图5示意性示出了根据本公开的实施例的数据库故障处理装置的框图;以及
图6示意性示出了根据本公开实施例的适于实现数据库故障处理方法的计算机系统的框图。
具体实施方式
以下,将参照附图来描述本公开的实施例。但是应该理解,这些描述只是示例性的,而并非要限制本公开的范围。在下面的详细描述中,为便于解释,阐述了许多具体的细节以提供对本公开实施例的全面理解。然而,明显地,一个或多个实施例在没有这些具体细节的情况下也可以被实施。此外,在以下说明中,省略了对公知结构和技术的描述,以避免不必要地混淆本公开的概念。
在此使用的术语仅仅是为了描述具体实施例,而并非意在限制本公开。在此使用的术语“包括”、“包含”等表明了所述特征、步骤、操作和/或部件的存在,但是并不排除存在或添加一个或多个其他特征、步骤、操作或部件。
在此使用的所有术语(包括技术和科学术语)具有本领域技术人员通常所理解的含义,除非另外定义。应注意,这里使用的术语应解释为具有与本说明书的上下文相一致的含义,而不应以理想化或过于刻板的方式来解释。
在使用类似于“A、B和C等中至少一个”这样的表述的情况下,一般来说应该按照本领域技术人员通常理解该表述的含义来予以解释(例如,“具有A、B和C中至少一个的系统”应包括但不限于单独具有A、单独具有B、单独具有C、具有A和B、具有A和C、具有B和C、和/或具有A、B、C的系统等)。在使用类似于“A、B或C等中至少一个”这样的表述的情况下,一般来说应该按照本领域技术人员通常理解该表述的含义来予以解释(例如,“具有A、B或C中至少一个的系统”应包括但不限于单独具有A、单独具有B、单独具有C、具有A和B、具有A和C、具有B和C、和/或具有A、B、C的系统等)。
图1示意性示出了相关技术中的大型机联机系统的架构图。
如图1所示,在相关技术中,IBM大型机中的每一个中间件CICS对应配置了一个DB2Connection,每个DB2 Connection里对应连接一个DB2 Member。当一个DB2 Member发生异常,如内存溢出、计数器异常或数据内部错位,会导致该CICS里所有联机交易访问数据库时出现异常中断。一般的故障应急处理流程是运维人员通过监控业务成功率,发现交易异常,再分析日志确定交易中断原因,并重启DB2Member。
因此,由于DB2 Member故障导致的问题,从监控发现、问题分析到故障恢复,都需要大量人工介入,故障解决的时效较低,此外还会导致有较多的联机交易失败,从而影响业务服务水平。
有鉴于此,本公开的实施例提供了一种数据库故障处理方法。该方法包括从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;将交易业务的交易信息传输至第二中间件;以及基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库。
根据本公开的实施例,根据业务异常信息,可以快速确定第一数据库存在异常,并将交易信息传输至第二中间件,利用第二中间件可以通过交易信息,及时访问没有出现异常的第二数据库,从而使得交易业务可以在第二中间件进行处理,不会影响交易业务的处理过程,前端的用户几乎感觉不到,所以至少部分地克服了相关技术中,对例如在IBM大型机联机系统出现故障的情况下,会影响大型机的前端业务服务水平相关技术中,对例如IBM大型机的故障查找效率较低,且会影响大型机的前端业务服务水平的技术问题。
图2示意性示出了根据本公开实施例的可以应用数据库故障处理方法的示例性系统架构200。需要注意的是,图2所示仅为可以应用本公开实施例的系统架构的示例,以帮助本领域技术人员理解本公开的技术内容,但并不意味着本公开实施例不可以用于其他设备、系统、环境或场景。
如图2所示,根据该实施例的系统架构200可以包括终端设备201、202、203,网络204和服务器205。网络204用以在终端设备201、202、203和服务器205之间提供通信链路的介质。网络204可以包括各种连接类型,例如有线和/或无线通信链路等等。
用户可以使用终端设备201、202、203通过网络204与服务器205交互,以接收或发送消息等。终端设备201、202、203上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端和/或社交平台软件等(仅为示例)。
终端设备201、202、203可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器205可以是提供各种服务的服务器,例如对用户利用终端设备201、202、203所浏览的网站提供支持的后台管理服务器(仅为示例)。后台管理服务器可以对接收到的用户请求等数据进行分析等处理,并将处理结果(例如根据用户请求获取或生成的网页、信息、或数据等)反馈给终端设备。
需要说明的是,本公开实施例所提供的数据库故障处理方法一般可以由服务器205执行。相应地,本公开实施例所提供的数据库故障处理装置一般可以设置于服务器205中。本公开实施例所提供的数据库故障处理方法也可以由不同于服务器205且能够与终端设备201、202、203和/或服务器205通信的服务器或服务器集群执行。相应地,本公开实施例所提供的数据库故障处理装置也可以设置于不同于服务器205且能够与终端设备201、202、203和/或服务器205通信的服务器或服务器集群中。
例如,业务异常信息可以由中间件发送给服务器,然后服务器可以基于业务异常信息在本地执行本公开实施例所提供的数据库故障处理方法,或者将业务异常信息发送到其他服务器或服务器集群,并由接收该业务异常信息的其他服务器或服务器集群来执行本公开实施例所提供的数据库故障处理方法。
应该理解,图2中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
图3示意性示出了根据本公开实施例的数据库故障处理方法的流程图。
如图3所示,该方法包括操作S301~S304。
在操作S301,从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常。
根据本公开的实施例,第一中间件可以是IBM大型机中的CICS,具体的,可以是出现交易业务处理异常的CICS。
根据本公开的实施例,CICS是IBM大型机上实时主机事务处理系统,简称中间件,大型机中的联机交易都可以在CICS中运行。CICS还可以为联机交易提供中央处理器(Central Processing Unit,CPU)调度、内存分配、负载均衡等功能。
根据本公开的实施例,交易业务可以是在第一中间件中处理的业务。
根据本公开的实施例,业务异常信息可以是第一中间件在处理交易业务的过程中出现的异常信息。
在操作S302,基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障。
根据本公开的实施例,第一数据库可以是与第一中间件相关联的数据库。例如,第一数据库可以是IBM大型机联机系统中的DB2中的其中一个DB2 Member,每个DB2 Member有独立的主控进程、缓冲池(Buffer Pool)、内存区域和日志文件。中间件可以通过DB2Connection访问关联的DB2 Member中的数据。
根据本公开的实施例,业务异常信息可以是在中间件调用第一数据库执行交易业务的情况下,联机系统记录的第一数据库的运行状态或者存储空间不符合预期状态的信息。可以从业务异常信息中确定预定字段信息,将预定字段信息与预定故障信息进行匹配。基于匹配结果,例如匹配结果表征预定字段信息与预定故障信息相同,确定与第一中间件相匹配的第一数据库存在故障。
在操作S303,将交易业务的交易信息传输至第二中间件。
根据本公开的实施例,第二中间件可以是CICS,具体的,可以是运行状态正常的CICS,有关CICS的描述可以参考上述对第一中间件的描述,在此不再赘述。
根据本公开的实施例,交易信息可以是用于处理交易业务的信息,例如,交易信息可以包括CICS名、交易名、通讯区数据(包含联机交易的通讯数据和业务请求的数据)、中断程序、中断类型、DB2 Connection、DB2 Member等中的一种或多种。
根据本公开的实施例,在确定与第一中间件相匹配的第一数据库存在故障的情况下,可以将交易业务的交易信息传输到第二中间件,以便通过第二中间件对交易业务进行处理。
根据本公开的实施例,可以通过故障捕获部署模块对联机系统进行参数配置,从而使得在第一中间件中出现业务异常信息的情况下,能够执行CICS系统程序退出命令(Enable Progran Exit),进而激活故障捕获模块。第一中间件可以自动调用故障捕获模块,从而通过故障捕获模块获取交易业务。
在操作S304,基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库。
根据本公开的实施例,第二数据库可以是与第二中间件相关联的数据库,第二数据库与第一数据库类似,有关第二数据库的描述可以参考上述对第一数据库的描述,在此不再赘述。
根据本公开的实施例,第二中间件可以通过与第二数据库相匹配的DB2Connection访问第二数据库,并根据交易业务重新进行业务处理,将处理完成的通讯信息沿交易业务的通讯链路返回到前端。根据本公开的实施例,采用了从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;将交易业务的交易信息传输至第二中间件;以及基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库的技术手段,使得根据业务异常信息,可以确定第一数据库存在异常,并将交易信息传输至第二中间件,利用第二中间件访问没有出现异常的第二数据库,从而使得交易业务可以在第二中间件进行处理,不会影响交易业务的处理过程,前端的用户几乎感觉不到,所以至少部分地克服了相关技术中,对例如在IBM大型机联机系统出现故障的情况下,会影响大型机的前端业务服务水平的技术问题。
根据本公开的实施例,上述数据库故障处理方法还包括:
标记第一数据库为故障恢复状态;以及
对第一数据库进行自动恢复。
根据本公开的实施例,在确定与第一中间件相匹配的第一数据库存在故障的情况下,可以利用故障分析模块将第一数据库标记为故障恢复状态,从而避免故障分析模块在收到同样的业务异常信息的情况下,对第一数据库进行重复恢复。
根据本公开的实施例,可以通过数据库自动恢复模块对第一数据库进行自恢复。数据库自恢复模块还会触发第一数据库的重启,以在应急的情况下恢复第一数据库。
根据本公开的实施例,对第一数据库自动恢复后,可以将第一数据库的状态设置为已恢复,待运维人员做进一步恢复处理,最后,第一数据库进行自恢复的结果发送给监控报警模块。
根据本公开的实施例,通过对第一数据库进行自动恢复,可以减少人工干预,提高数据库故障的处理效率。
根据本公开的实施例,上述数据库故障处理方法还包括:
从预定的数据库列表中确定运行正常的第三数据库,其中,预定的数据库列表用于表征联机系统中的逻辑分区和数据库之间的对应关系,第三数据库和第一数据库分别与联机系统中的同一逻辑分区相对应;以及
将第一中间件与第一数据库的映射关系替换为第一中间件与第三数据库的映射关系。
根据本公开的实施例,联机系统可以是由多台主机构成的后台处理系统,例如,联机系统可以是IBM大型机中的联机系统。
根据本公开的实施例,逻辑分区(LPAR)可以是IBM大型机中的联机系统中的分区,联机系统可以被划分成若干个虚拟或逻辑的服务器,每个虚拟或逻辑的服务器运行独立的操作系统,有各自独享的处理器、内存和计算机接口(Input/Output,I/O)资源。
根据本公开的实施例,第三数据库与第一数据库类似,有关第三数据库的描述可以参考上述对第一数据库的描述,在此不再赘述。
根据本公开的实施例,预定的数据库列表可以是联机系统中的多个数据库与多个逻辑分区一一对应的关系表。
根据本公开的实施例,可以从预定的数据库列表查询到第一数据库对应的逻辑分区,根据第一数据库对应的逻辑分区确定运行正常的第三数据库。
根据本公开的实施例,第一中间件和第一数据库可以通过DB2Connection确定映射关系,通过预定的数据库列表可以查询到与第一数据库对应的可以通过修改第一中间件和第一数据库的DB2Connection的数据库识别号码(DB2 ID),将第一中间件与第一数据库的映射关系替换为第一中间件与第三数据库的映射关系,实现了将第一中间的DB2Connection连接到第三数据库。
根据本公开的实施例,可以通过数据库自动恢复模块将第一中间件与第一数据库的映射关系替换为第一中间件与第三数据库的映射关系。
根据本公开的实施例,通过确定与第一数据库位于相同分区的第三数据库,并将第一中间件与第一数据库的映射关系替换为第一中间件与第三数据库的映射关系,从而将第一中间件的交易业务传输至运行正常的第三数据库,进行交易业务的重试,使得交易业务通过第三数据库正常完成处理,前端用户不会感知业务处理异常。
根据本公开的实施例,其中,从第一中间件中获取业务异常信息,包括:
在交易业务存在异常的情况下,接收来自第一中间件的故障报警;以及
基于故障报警,从第一中间件中获取业务异常信息,其中,业务异常信息包括以下至少一项:与交易业务相关的请求信息、与交易业务相关的通信信息、与故障相关的标识信息。
根据本公开的实施例,在交易业务存在异常的情况下,第一中间可以发出故障报警。例如,在交易业务发生中断的情况下,可以发出业务终端的故障报警;在DB2 Member的内存溢出、计数器异常或数据内部错位的情况下,也可以发出业务中断的故障报警。
根据本公开的实施例,通过第一中间件发出的故障报警,可以及时获取准确的业务异常信息。
根据本公开的实施例,其中,在交易业务存在异常的情况下,接收来自第一中间件的故障报警,包括:
在交易业务存在异常的情况下,利用故障捕获模块获取来自第一中间件的故障报警,其中,故障捕获模块装载于第一中间件中,故障捕获模块用于对故障进行实时监控。
根据本公开的实施例,故障捕获模块可以通过程序装载于第一中间件中,当交易业务存在异常的情况下,第一中间件可以自动调用故障捕获模块。
根据本公开的实施例,故障捕获模块实现将故障捕获功能嵌入到第一中间件中,不需要入侵业务代码。
根据本公开的实施例,其中,基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障,包括:
基于业务异常信息,确定与业务异常信息相匹配的故障解析信息;以及
基于故障解析信息,确定与第一中间件相匹配的第一数据库存在故障。
根据本公开的实施例,故障解析信息可以是对业务异常信息进行解析后得到的信息。例如,故障解析信息可以是交易业务对应的环境名称、交易代码、交易开始时间以及结束时间等等。
根据本公开的实施例,可以对故障解析信息进行分析,从而确定第一数据库存在故障。例如,可以对交易业务对应的环境名称、交易代码、交易开始时间以及结束时间进行分析,从而确定具体的故障的问题。
根据本公开的实施例,通过确定故障解析信息,可以确定第一数据库具体的故障问题,能够快速对故障进行定位。
根据本公开的实施例,上述数据库故障处理方法还包括:
基于业务异常信息,对交易业务进行回滚处理;以及
停止利用第一中间件处理交易业务。
根据本公开的实施例,可以基于业务异常信息,对交易业务进行回滚处理。例如,对交易业务进行数据更新、新增或者删除的操作,从而保证数据一致性。
根据本公开的实施例,可以利用故障模块对交易业务进行回滚处理,并停止利用第一中间件处理交易业务。
根据本公开的实施例,可以停止利用第一中间件处理交易业务,不让交易业务继续处理,也不让交易业务返回错误码到前端,从而避免跟重试的交易业务发生冲突。
根据本公开的实施例,其中,将交易业务的交易信息传输至第二中间件,包括:
从预定的中间件列表中确定运行正常的第二中间件,其中,预定的中间件列表用于表征联机系统中的逻辑分区和中间件之间的对应关系,第一中间件和第二中间件分别与联机系统中的同一逻辑分区相对应;以及
将交易业务的交易信息传输至第二中间件。
根据本公开的实施例,联机系统中可以有多个中间件,多个中间件可以与多个逻辑分区有对应关系,从而得到预定的中间件列表。
根据本公开的实施例,通过预定的中间列表可以确定与第一中间件对应的逻辑分区,从而确定运行正常的第二中间件,将交易信息传输至第二中间件。
图4示意性示出了根据本公开实施例的可以应用数据库故障处理方法的系统框图。
如图4所示,该系统中设置有故障捕获部署模块,可以通过故障捕获部署模块对联机系统进行参数配置,从而使得在第一中间件中出现业务异常信息的情况下,能够执行CICS系统程序退出命令(Enable Progran Exit),进而激活故障捕获模块。故障捕获模块激活后会嵌入到第一中间件的底层处理模块中,第一中间件可以自动调用故障捕获模块,从而通过故障捕获模块获取交易业务。
根据本公开的实施例,在第一中间件中的交易业务出现处理异常的情况下,可以通过第一中间件发出故障报警,并通过故障捕获模块获取第一中间件的故障报警,可以基于故障报警,从第一中间件中获取业务异常信息,并基于业务异常信息,确定第一数据库DB2Member1存在故障,从而将交易信息传输至第二中间件CICS2,利用第二中间件访问第二数据库DB2 Member 2。
根据本公开的实施例,该系统可以设置数据库自动恢复模块,通过数据库自动恢复模块可以对第一数据库进行自动恢复,还可以将第一中间件CICS1与第一数据库DB2Member1的DB2 CONNECTION映射关系替换为第一中间件与第三数据库DB2 Member3的映射关系。
根据本公开的实施例,该系统可以设置故障分析模块,通过故障分析模块可以对业务异常信息进行分析,从而确定故障解析信息,例如,故障分析模块分析业务异常信息,判断中断码为CICS中断码(AD2R),也就是交易业务在访问第一数据库的过程中,第一数据库发生异常。可以通过传输模块将业务信息传输至第二中间件,并将第一数据库标记为故障恢复状态,从而避免故障分析模块在收到同样的业务异常信息的情况下,对第一数据库进行重复恢复。
根据本公开的实施例,该系统还可以设置监控报警模块,通过监控报警模块可以获取交易业务在第二中间件的执行情况以及第一数据库的自恢复情况,并将获取到的信息发送至第一中间件进行故障报警和恢复处理日志登记。
图5示意性示出了根据本公开的实施例的数据库故障处理装置的框图。
如图5所示,数据库故障处理装置500包括获取模块510、确定模块520、传输模块530和访问模块540。
获取模块510,用于从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;
确定模块520,用于基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;
传输模块530,用于将交易业务的交易信息传输至第二中间件;以及
访问模块540,用于基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库。
根据本公开的实施例,采用了从第一中间件中获取业务异常信息,其中,业务异常信息用于表征交易业务处理异常;基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障;将交易业务的交易信息传输至第二中间件;以及基于交易信息,利用第二中间件访问与第二中间件相匹配的第二数据库的技术手段,使得根据业务异常信息,可以确定第一数据库存在异常,并将交易信息传输至第二中间件,利用第二中间件访问没有出现异常的第二数据库,从而使得交易业务可以在第二中间件进行处理,不会影响交易业务的处理过程,由此使得前端的用户感觉不到,所以至少部分地克服了相关技术中,对例如在IBM大型机联机系统出现数据库故障的情况下,会影响大型机的前端业务服务水平的技术问题。
根据本公开的实施例,上述数据库故障处理装置500还包括标记模块和自动恢复模块。
标记模块,用于标记第一数据库为故障恢复状态;以及
自动恢复模块,用于对第一数据库进行自动恢复。
根据本公开的实施例,上述数据库故障处理装置500还包括第三数据库确定模块和替换模块。
第三数据库确定模块,用于从预定的数据库列表中确定运行正常的第三数据库,其中,预定的数据库列表用于表征联机系统中的逻辑分区和数据库之间的对应关系,第三数据库和第一数据库分别与联机系统中的同一逻辑分区相对应;以及
替换模块,用于将第一中间件与第一数据库的映射关系替换为第一中间件与第三数据库的映射关系。
根据本公开的实施例,其中,用于从第一中间件中获取业务异常信息的获取模块510包括第一获取单元和第二获取单元。
第一获取单元,用于在交易业务存在异常的情况下,接收来自第一中间件的故障报警;以及
第二获取单元,用于基于故障报警,从第一中间件中获取业务异常信息,其中,业务异常信息包括以下至少一项:与交易业务相关的请求信息、与交易业务相关的通信信息、与故障相关的标识信息。
根据本公开的实施例,其中,用于在交易业务存在异常的情况下,接收来自第一中间件的故障报警的第一获取单元包括获取子单元:
获取子单元,用于在交易业务存在异常的情况下,利用故障捕获模块获取来自第一中间件的故障报警,其中,故障捕获模块装载于第一中间件中,故障捕获模块用于对故障进行实时监控。
根据本公开的实施例,其中,基于业务异常信息,确定与第一中间件相匹配的第一数据库存在故障的确定模块520包括第一确定单元和第二确定单元:
第一确定单元,用于基于业务异常信息,确定与业务异常信息相匹配的故障解析信息;以及
第二确定单元,用于基于故障解析信息,确定与第一中间件相匹配的第一数据库存在故障。
根据本公开的实施例,上述数据库故障处理装置500还包括回滚处理模块和停止模块。
回滚处理模块,用于基于业务异常信息,对交易业务进行回滚处理;以及
停止模块,用于停止利用第一中间件处理交易业务。
根据本公开的实施例,其中,用于将交易业务的交易信息传输至第二中间件的传输模块530包括第一传输单元和第二传输单元:
第一传输单元,用于从预定的中间件列表中确定运行正常的第二中间件,其中,预定的中间件列表用于表征联机系统中的逻辑分区和中间件之间的对应关系,第一中间件和第二中间件分别与联机系统中的同一逻辑分区相对应;以及
第二传输单元,用于将交易业务的交易信息传输至第二中间件。
根据本公开的实施例的模块、子模块、单元、子单元中的任意多个、或其中任意多个的至少部分功能可以在一个模块中实现。根据本公开实施例的模块、子模块、单元、子单元中的任意一个或多个可以被拆分成多个模块来实现。根据本公开实施例的模块、子模块、单元、子单元中的任意一个或多个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以通过对电路进行集成或封装的任何其他的合理方式的硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,根据本公开实施例的模块、子模块、单元、子单元中的一个或多个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。
例如,获取模块510、确定模块520、传输模块530和访问模块540中的任意多个可以合并在一个模块/单元/子单元中实现,或者其中的任意一个模块/单元/子单元可以被拆分成多个模块/单元/子单元。或者,这些模块/单元/子单元中的一个或多个模块/单元/子单元的至少部分功能可以与其他模块/单元/子单元的至少部分功能相结合,并在一个模块/单元/子单元中实现。根据本公开的实施例,获取模块510、确定模块520、传输模块530和访问模块540中的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以通过对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,获取模块510、确定模块520、传输模块530和访问模块540中的至少一个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。
需要说明的是,本公开的实施例中数据库故障处理装置部分与本公开的实施例中数据库故障处理方法部分是相对应的,数据库故障处理装置部分的描述具体参考数据库故障处理方法部分,在此不再赘述。
图6示意性示出了根据本公开实施例的适于实现上文描述的方法的计算机系统的框图。图6示出的计算机系统仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图6所示,根据本公开实施例的计算机系统600包括处理器601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。处理器601例如可以包括通用微处理器(例如CPU)、指令集处理器和/或相关芯片组和/或专用微处理器(例如,专用集成电路(ASIC)),等等。处理器601还可以包括用于缓存用途的板载存储器。处理器601可以包括用于执行根据本公开实施例的方法流程的不同动作的单一处理单元或者是多个处理单元。
在RAM 603中,存储有系统600操作所需的各种程序和数据。处理器601、ROM 602以及RAM 603通过总线604彼此相连。处理器601通过执行ROM 602和/或RAM 603中的程序来执行根据本公开实施例的方法流程的各种操作。需要注意,所述程序也可以存储在除ROM 602和RAM 603以外的一个或多个存储器中。处理器601也可以通过执行存储在所述一个或多个存储器中的程序来执行根据本公开实施例的方法流程的各种操作。
根据本公开的实施例,系统600还可以包括输入/输出(I/O)接口605,输入/输出(I/O)接口605也连接至总线604。系统600还可以包括连接至I/O接口605的以下部件中的一项或多项:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便于从其上读出的计算机程序根据需要被安装入存储部分608。
根据本公开的实施例,根据本公开实施例的方法流程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读存储介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被处理器601执行时,执行本公开实施例的系统中限定的上述功能。根据本公开的实施例,上文描述的系统、设备、装置、模块、单元等可以通过计算机程序模块来实现。
本公开还提供了一种计算机可读存储介质,该计算机可读存储介质可以是上述实施例中描述的设备/装置/系统中所包含的;也可以是单独存在,而未装配入该设备/装置/系统中。上述计算机可读存储介质承载有一个或者多个程序,当上述一个或者多个程序被执行时,实现根据本公开实施例的方法。
根据本公开的实施例,计算机可读存储介质可以是非易失性的计算机可读存储介质。例如可以包括但不限于:便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
例如,根据本公开的实施例,计算机可读存储介质可以包括上文描述的ROM 602和/或RAM 603和/或ROM 602和RAM 603以外的一个或多个存储器。
本公开的实施例还包括一种计算机程序产品,其包括计算机程序,该计算机程序包含用于执行本公开实施例所提供的方法的程序代码,当计算机程序产品在电子设备上运行时,该程序代码用于使电子设备实现本公开实施例所提供的数据库故障处理方法。
在该计算机程序被处理器601执行时,执行本公开实施例的系统/装置中限定的上述功能。根据本公开的实施例,上文描述的系统、装置、模块、单元等可以通过计算机程序模块来实现。
在一种实施例中,该计算机程序可以依托于光存储器件、磁存储器件等有形存储介质。在另一种实施例中,该计算机程序也可以在网络介质上以信号的形式进行传输、分发,并通过通信部分609被下载和安装,和/或从可拆卸介质611被安装。该计算机程序包含的程序代码可以用任何适当的网络介质传输,包括但不限于:无线、有线等等,或者上述的任意合适的组合。
根据本公开的实施例,可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例提供的计算机程序的程序代码,具体地,可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。程序设计语言包括但不限于诸如Java,C++,python,“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。本领域技术人员可以理解,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合和/或结合,即使这样的组合或结合没有明确记载于本公开中。特别地,在不脱离本公开精神和教导的情况下,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合和/或结合。所有这些组合和/或结合均落入本公开的范围。
以上对本公开的实施例进行了描述。但是,这些实施例仅仅是为了说明的目的,而并非为了限制本公开的范围。尽管在以上分别描述了各实施例,但是这并不意味着各个实施例中的措施不能有利地结合使用。本公开的范围由所附权利要求及其等同物限定。不脱离本公开的范围,本领域技术人员可以做出多种替代和修改,这些替代和修改都应落在本公开的范围之内。

Claims (12)

1.一种数据库故障处理方法,包括:
从第一中间件中获取业务异常信息,其中,所述业务异常信息用于表征交易业务处理异常;
基于所述业务异常信息,确定与所述第一中间件相匹配的第一数据库存在故障;
将所述交易业务的交易信息传输至第二中间件;以及
基于所述交易信息,利用所述第二中间件访问与所述第二中间件相匹配的第二数据库。
2.根据权利要求1所述的方法,还包括:
标记所述第一数据库为故障恢复状态;以及
对所述第一数据库进行自动恢复。
3.根据权利要求1或2所述的方法,还包括:
从预定的数据库列表中确定运行正常的第三数据库,其中,所述预定的数据库列表用于表征联机系统中的逻辑分区和数据库之间的对应关系,所述第三数据库和所述第一数据库分别与所述联机系统中的同一逻辑分区相对应;以及
将所述第一中间件与所述第一数据库的映射关系替换为所述第一中间件与所述第三数据库的映射关系。
4.根据权利要求1所述的方法,其中,所述从第一中间件中获取业务异常信息,包括:
在所述交易业务存在异常的情况下,接收来自所述第一中间件的故障报警;以及
基于所述故障报警,从所述第一中间件中获取业务异常信息,其中,所述业务异常信息包括以下至少一项:与所述交易业务相关的请求信息、与所述交易业务相关的通信信息、与故障相关的标识信息。
5.根据权利要求4所述的方法,其中,在所述交易业务存在异常的情况下,接收来自所述第一中间件的故障报警,包括:
在所述交易业务存在异常的情况下,利用故障捕获模块获取来自所述第一中间件的故障报警,其中,所述故障捕获模块装载于所述第一中间件中,所述故障捕获模块用于对故障进行实时监控。
6.根据权利要求1所述的方法,其中,所述基于所述业务异常信息,确定与所述第一中间件相匹配的第一数据库存在故障,包括:
基于所述业务异常信息,确定与所述业务异常信息相匹配的故障解析信息;以及
基于所述故障解析信息,确定与所述第一中间件相匹配的第一数据库存在故障。
7.根据权利要求1所述的方法,还包括:
基于所述业务异常信息,对所述交易业务进行回滚处理;以及
停止利用所述第一中间件处理所述交易业务。
8.根据权利要求1所述的方法,其中,所述将所述交易业务的交易信息传输至第二中间件,包括:
从预定的中间件列表中确定运行正常的所述第二中间件,其中,所述预定的中间件列表用于表征联机系统中的逻辑分区和中间件之间的对应关系,所述第一中间件和所述第二中间件分别与所述联机系统中的同一逻辑分区相对应;以及
将所述交易业务的交易信息传输至所述第二中间件。
9.一种数据库故障处理装置,包括:
获取模块,用于从第一中间件中获取业务异常信息,其中,所述业务异常信息用于表征交易业务处理异常;
确定模块,用于基于所述业务异常信息,确定与所述第一中间件相匹配的第一数据库存在故障;
传输模块,用于将所述交易业务的交易信息传输至第二中间件;以及
访问模块,用于基于所述交易信息,利用所述第二中间件访问与所述第二中间件相匹配的第二数据库。
10.一种电子设备,包括:
一个或多个处理器;
存储器,用于存储一个或多个指令,
其中,当所述一个或多个指令被所述一个或多个处理器执行时,使得所述一个或多个处理器实现权利要求1至8中任一项所述的方法。
11.一种计算机可读存储介质,其上存储有可执行指令,所述指令被处理器执行时使处理器实现权利要求1至8中任一项所述的方法。
12.一种计算机程序产品,所述计算机程序产品包括计算机可执行指令,所述指令在被执行时用于实现权利要求1至8中任一项所述的方法。
CN202210996686.9A 2022-08-19 2022-08-19 数据库故障处理方法、装置、电子设备及存储介质 Pending CN115292100A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210996686.9A CN115292100A (zh) 2022-08-19 2022-08-19 数据库故障处理方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210996686.9A CN115292100A (zh) 2022-08-19 2022-08-19 数据库故障处理方法、装置、电子设备及存储介质

Publications (1)

Publication Number Publication Date
CN115292100A true CN115292100A (zh) 2022-11-04

Family

ID=83831064

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210996686.9A Pending CN115292100A (zh) 2022-08-19 2022-08-19 数据库故障处理方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN115292100A (zh)

Similar Documents

Publication Publication Date Title
US10152382B2 (en) Method and system for monitoring virtual machine cluster
US7979749B2 (en) Method and infrastructure for detecting and/or servicing a failing/failed operating system instance
US11392461B2 (en) Method and apparatus for processing information
US8713378B2 (en) Health monitoring of applications in a guest partition
US9495234B1 (en) Detecting anomalous behavior by determining correlations
US10489232B1 (en) Data center diagnostic information
US9122595B2 (en) Fault tolerance for complex distributed computing operations
CN113900834B (zh) 基于物联网技术的数据处理方法、装置、设备及存储介质
US11221907B1 (en) Centralized software issue triage system
JP5425720B2 (ja) 仮想化環境監視装置とその監視方法およびプログラム
CN114884796A (zh) 故障处理方法、装置、电子设备及存储介质
CN111538585A (zh) 一种基于node.js的服务器进程调度方法、系统和装置
US20220012216A1 (en) Monitoring database management systems connected by a computer network
CN116841902A (zh) 健康状态检查方法、装置、设备及存储介质
US11656930B2 (en) Minimizing impact of first failure data capture on computing system using recovery process boost
CN115292100A (zh) 数据库故障处理方法、装置、电子设备及存储介质
CN113760579A (zh) 一种故障排查方法及装置
CN113419887A (zh) 主机联机事务异常的处理方法及装置
CN111581058A (zh) 故障管理方法、装置、设备及计算机可读存储介质
CN111488230A (zh) 修改日志输出级别的方法、装置、电子设备及存储介质
CN116820526B (zh) 操作系统升级方法、装置、设备及存储介质
CN116483566A (zh) 用于服务器的资源处理方法、装置、电子设备及存储介质
CN115190008A (zh) 故障处理方法、故障处理装置、电子设备及存储介质
CN114296884A (zh) 容器化应用的部署方法、装置和电子设备
CN116975200A (zh) 用于控制服务器工作状态的方法、装置、设备及介质

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination