CN112015595A - 主从数据库的切换方法、计算设备及存储介质 - Google Patents

主从数据库的切换方法、计算设备及存储介质 Download PDF

Info

Publication number
CN112015595A
CN112015595A CN202010887335.5A CN202010887335A CN112015595A CN 112015595 A CN112015595 A CN 112015595A CN 202010887335 A CN202010887335 A CN 202010887335A CN 112015595 A CN112015595 A CN 112015595A
Authority
CN
China
Prior art keywords
database
master
slave
data
master database
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
CN202010887335.5A
Other languages
English (en)
Other versions
CN112015595B (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.)
Ireader Technology Co Ltd
Original Assignee
Ireader Technology 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 Ireader Technology Co Ltd filed Critical Ireader Technology Co Ltd
Priority to CN202010887335.5A priority Critical patent/CN112015595B/zh
Publication of CN112015595A publication Critical patent/CN112015595A/zh
Application granted granted Critical
Publication of CN112015595B publication Critical patent/CN112015595B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

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/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1446Point-in-time backing up or restoration of persistent data
    • G06F11/1458Management of the backup or restore process
    • G06F11/1461Backup scheduling policy
    • 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
    • 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/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor

Landscapes

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

Abstract

本发明公开了一种主从数据库的切换方法、计算设备及存储介质,该方法包括:监控当前的第一主数据库是否发生宕机;当监控到该当前的第一主数据库宕机时,根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库;利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库;选取新的第三主数据库;利用该第一主数据库中的插件,读取该第一主数据库的待同步数据,将该第一主数据库的待同步数据写入到该第三主数据库中;更新切换后的主从数据库的配置信息。通过上述本发明方案,可以在当前的主数据库宕机时,及时的将一从数据库切换为主数据,并可确保数据不丢失。

Description

主从数据库的切换方法、计算设备及存储介质
技术领域
本发明涉及数据库技术领域,具体涉及一种主从数据库的切换方法、计算设备及存储介质。
背景技术
主从数据库通常由一个主数据库和多个从数据库构成,其中,主数据库同时具有数据读取和写入的功能,而从数据库通过与主数据库中的数据保持同步,则可向业务方独立提供数据读取功能,分散主数据库的访问压力,解决仅从主数据库读取数据慢的问题。与此同时,保持主数据库的可用性,是实现上述主数据库读写以及分压的前提,即需要始终保持有正常提供数据读写功能的主数据。
在现有技术中,通常是通过获取主数据库和各个从数据的权限,并在当前数据库宕机时,利用对该主数据库的权限到主数据库上拿取数据,再利用对某个适于作为新的主数据库的从数据库的权限,到该从数据库去,并将数据送到该从数据库中,然后将该从数据库提为新的主数据库。
然而,发明人在实施本发明实施例的过程中发现,上述现有技术至少存在如下技术问题:上述现有技术中必须拥有每个数据库的权限,并利用该权限到主数据库中拿数据以及将拿到的数据送至新的主数据库中,这将极大地降低数据库切换的效率,使得业务长时间不能使用,增强了用户的故障感知。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的主从数据库的切换方法、计算设备及存储介质。
根据本发明实施例的一个方面,提供了一种主从数据库的切换方法,包括:
监控当前的第一主数据库是否发生宕机;
当监控到所述当前的第一主数据库宕机时,根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库;
利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库;
根据所述临时的第二主数据库和所述其它从数据库的角色权重配置信息,选取新的第三主数据库;
利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理;
更新切换后的主从数据库的配置信息。
根据本发明的再一个方面,提供了一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;
所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行主从数据库的切换方法对应的操作。
根据本发明实施例的又一方面,提供了一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行主从数据库的切换方法对应的操作。
根据本发明的主从数据库的切换方法、计算设备及存储介质,在监控到当前的第一主数据库发生宕机后,首先根据各个从数据库的数据同步位置信息,选取出临时的第二主数据库,并利用主从同步功能将其它从数据库中的数据同步到与临时的第二主数据库中的数据一致,以减少后续利用插件进行补全的数据量;然后,在完成数据同步后,基于角色权重配置信息选取出新的第三主数据库,并利用第一主数据库中的插件将第一数据库的待同步数据补全到第三主数据库中,使得第三主数据库中的数据与宕机前第一数据库中的数据完全一致,避免第三主数据库的数据缺失,以确保第三主数据可提供与第一主数据库相同服务;最后,修改该主从数据库的配置信息,以方便业务方读取并请求服务。由此可见,本发明方案,通过主从同步功能结合插件补全方式使新的第三主数据库的数据与宕机的第一主数据库中的数据完全一致,相较于现有技术中通过获取数据库权限而进入旧的主数据库中拿取数据并将该数据送入到新的主数据库中的方式,可以提高切换的整体效率。
上述说明仅是本发明实施例技术方案的概述,为了能够更清楚了解本发明实施例的技术手段,而可依照说明书的内容予以实施,并且为了让本发明实施例的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明实施例的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明实施例的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了本发明实施例提供的主从数据库的切换方法的流程图;
图2示出了本发明另一个实施例提供的主从数据库的切换方法的流程图;
图3示出了一个具体示例中的主从数据库结构的示意图;
图4是示出了对应图3的主从数据库的数据补全过程的示意图;
图5示出了本发明实施例提供的计算设备的结构示意图。
具体实施方式
下面将参照附图更详细地描述本发明的示例性实施例。虽然附图中显示了本发明的示例性实施例,然而应当理解,可以以各种形式实现本发明而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本发明,并且能够将本发明的范围完整的传达给本领域的技术人员。
图1示出了本发明实施例提供的主从数据库的切换方法的流程图。该方法用于在当前的主数据库宕机时,将主从数据库中的一从数据库切换为新的主数据库。该方法可由任意具有数据数据处理能力的计算设备来执行,优选的,该计算设备中具有专用于主从数据库切换的切换***。如图1所示,该方法包括以下步骤:
步骤S110:监控当前的第一主数据库是否发生宕机。
其中,第一主数据库即为当前提供读写功能的主数据库。
具体地,持续实时的监控该第一主数据库是否发生宕机,一旦监控到发生宕机,则执行步骤S120及其后续步骤,以实现主数据库的及时切换,避免影响业务。
步骤S120:当监控到该当前的第一主数据库宕机时,根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库;利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库。
实际中,主数据库向各个从数据库进行数据同步的传输速率存在差异,导致各个从数据库中的同步数据不完全一致。其中,任一从数据库的数据同步位置信息是指该从数据库中已有的同步数据,在第一主数据库中的数据位置,该数据同步位置信息可反映出同步进度。举例来说,若从数据库1的数据同步位置信息为9,则表示该从数据库1中的同步数据已同步到第一主数据库中的第9条数据。
具体地,各个从数据库的数据同步位置信息可反映出各自的同步进度,其中,同步进度越快,则表示已有的同步数据越多,而待同步的数据则越少,相应的,则后续需要同步的工作量越少,基于此,从多个从数据库中选取临时的第二主数据库,以用于向其它从数据库同步数据,减少后续同步的工作量。需要在此说明的是,本发明中不限定具体的选取方式,例如,可选取数据同步位置信息显示的同步进度最快的从数据库作为临时的第二从数据库,以最大限度减少后续利用插件同步的数据量,或者,也可从数据同步位置信息显示的同步进度排在前预设名次的从数据库中,选择网络配置最优的从数据库作为临时的第二从数据库,在减少后续利用插件同步的数据量时,进一步确保利用良好的网络配置在尽可能短的时间内实现多个从数据库中的数据同步。
以及,在选取出第二主数据库后,利用主从数据库的主从同步功能将第二主数据库的待同步数据同步给其它从数据库,该主从同步功能是主从数据库的内部机制,相较于其它辅助实现数据同步的方式(包括现有技术中的获取权限同步的方式以及后文中的插件同步方式),其在同步数据时的效率是最高的,可以高效的使多个从数据库均同步到一致的位置。并且,各个其它从数据库具有相应的第二主数据库的待同步数据,其它从数据库的数据同步位置信息不同,则该其它从数据库的第二主数据库的待同步数据不同。
举例来说,第二主数据库的数据同步位置信息为10,其它从数据库1以及从数据库2的数据同步位置信息分别为9和8,则相对于从数据库1,第二主数据库的待同步数据为最新的一条数据(10-9=1),相对于从数据库2而言,第二主数据库的待同步数据为最新的两条数据(10-8=2),利用主从同步功能将上述待同步数据分别同步至从数据库1和从数据库2,同步完成后则第二主数据库以及从数据库1和从数据库2的同步数据均为10条,保持了一致。
步骤S130:根据该临时的第二主数据库和该其它从数据库的角色权重配置信息,选取新的第三主数据库;利用该第一主数据库中的插件,查询该第一主数据库的待同步数据,并根据查询结果对该第三主数据库进行数据补全处理。
其中,角色权重配置信息为适宜作为新的第三主数据库的指标,其反映了临时的第二主数据库和其他从数据库被选取为新的第三主数据库的优先级。
以及,第一主数据库中部署有数据补全插件(本文中简称为插件),用于在该第一主数据库宕机时,利用该插件对第三主数据库中的同步数据进行补全处理。由于第一主数据库已宕机,只能通过辅助方式(本实施例中通过插件方式)来进行数据补全,避免新的第三主数据库中缺失数据。
具体地,根据临时的第二主数据库和其它从数据库的角色权重配置信息反映的优先级排序,选取新的第三主数据,用于替换第一主数据库。在选取出新的第三主数据库后,利用第一主数据库中的插件查询第一主数据库中的待同步数据,并将查询到的该待同步数据补全到第三主数据库中,以使第三主数据库中具有与宕机前的第一主数据库一致的数据,其中,第一主数据库中的待同步数据是指第一主数据库中存在,而第三主数据库中不存在的数据。此处利用插件补全数据的过程的效率比利用主从同步功能同步数据的效率要低,本实施例中通过先选取出临时的第二主数据库并利用主从同步功能进行同步,可以减少后续利用插件进行补全的数据量,然后再利用插件进行补全,则可确保切换前后的主数据库中的数据一致的同时,可提高整个将第一主数据库中的数据同步至第三主数据库中的过程的效率。
步骤S140:更新切换后的主从数据库的配置信息。
在完成将第一主数据库中的数据补全到第三主数据库中后,修改主从数据库的配置信息,使业务方通过读取更新的配置可以继续从主从数据库中获取服务。
根据本实施例提供的主从数据库的切换方法,在监控到当前的第一主数据库发生宕机后,首先根据各个从数据库的数据同步位置信息,选取出临时的第二主数据库,并利用主从同步功能将其它从数据库中的数据同步到与临时的第二主数据库中的数据一致,以减少后续利用插件进行补全的数据量;然后,在完成数据同步后,基于角色权重配置信息选取出新的第三主数据库,并利用第一主数据库中的插件将第一数据库的待同步数据补全到第三主数据库中,使得第三主数据库中的数据与宕机前第一数据库中的数据完全一致,避免第三主数据库的数据缺失,以确保第三主数据可提供与第一主数据库相同服务;最后,修改该主从数据库的配置信息,以方便业务方读取并请求服务。由此可见,本实施例方案,通过主从同步功能结合插件补全方式使新的第三主数据库的数据与宕机的第一主数据库中的数据完全一致,相较于现有技术中通过获取数据库权限而进入旧的主数据库中拿取数据并将该数据送入到新的主数据库中的方式,可以提高切换的整体效率。
图2示出了本发明另一个实施例提供的主从数据库的切换方法的流程图。其中,主从数据库可以为本领域技术人员所熟知的任意类型的数据库,例如,mysql数据库,此处不再一一列举。如图2所示,该方法包括以下步骤:
步骤S210:监控当前的第一主数据库是否发生宕机。
在本发明中,并不限定监控第一主数据库是否发生宕机的具体方式,实际实施时,本领域技术人员可根据实际情况进行灵活选择。通常情况下,可通过与主数据库建立连接,并监控主数据库的心跳来确定该主数据库是否发生宕机。
而在一些可选的实施方式中,可通过建立与该第一主数据库以及多个从数据库的连接,即建立执行本发明实施例方案的计算设备或者计算设备中的切换***与主从数据库中的每个数据库的连接,然后通过以下方式来进行监控;监控是否可与该第一主数据库联通,若不可联通,则询问该多个从数据库是否与该第一主数据库保持连接;根据该多个从数据库返回的询问结果判断该第一主数据库是否发生宕机。在这些可选的实施方式中,利用计算设备(或切换***)与第一主数据库的联通与否以及各个从数据库上报的其与第一主数据库的连接状态,该两层监控来最终确定是否发生宕机,可以提高宕机监控的准确性。进一步的,可在计算设备(或切换***)与第一主数据库不可联通的情况下,依据返回未与第一主数据库保持连接的询问结果的从数据库的数量来判断第一主数据库是否发生宕机,例如,超过预设数量的从数据库返回未与第一主数据库保持连接的询问结果,则判定第一主数据库宕机;优选的,若所有从数据库均返回未与该第一主数据库保持连接的询问结果,则判定该第一主数据库发生宕机。
另外,在本发明实施例中,还需要检测该主从数据库的主数据库和/或从数据库是否发生更新;若是,则建立与新增的主数据库和/或从数据库的连接,或者断开与删除的主数据库和/或从数据库的连接,以确保可以准确的对第一主数据库进行宕机监控,
步骤S220:根据各个从数据库的数据同步位置信息确定出同步进度最快的目标从数据库;将该目标从数据库选取为临时的第二主数据库;利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库。
在本发明实施例中,以同步数据的多少来选取临时的第二主数据库。
具体地,比较多个从数据库的数据同步位置信息,确定出同步进度最快的目标从数据库,将该目标从数据库选取为临时的第二主数据库,然后利用主从同步功能在第二主数据库和其余从数据库之间进行数据同步,则可以将其它从数据库中的同步数据同步至与第二主数据库中的数据一致,达到最多的同步数据。
图3示出了一个具体示例中的主从数据库结构的示意图。如图3所示,IP为1.1.1.1的数据库为第一主数据库,IP为2.2.2.2,3.3.3.3以及4.4.4.4的数据库分别为从数据库1,从数据库2以及从数据库3,其中数据点为数据同步位置信息,从数据库的数据点即表示第一主数据库中复制到各个从数据库中的同步数据的位置,例如,从数据库1的数据点为9,则表示同步到第9条数据,当第一主数据库宕机后,则无法正常向各个从数据库复制数据,比较数据点大小可确定从数据库2的同步进度最快,则将该从数据库2选取为临时的第二主数据库。然后,利用主从同步功能将从数据库1和从数据库3中的数据同步到与从数据2中的数据一致,达到10条。
步骤S230:根据该临时的第二主数据库和该其它从数据库的角色权重配置信息,选取新的第三主数据库。
具体地,在完成前述主从同步后,根据多个从数据库的机器配置,为该多个从数据库设置角色权重配置信息,以使从数据库的角色权重与其机器配置相适应,通常情况下,按照机器配置由高至低,为多个从数据库设置反映的角色权重由高至低的角色权重配置信息。其中,仅用作备份的从数据库通常硬件配置较低,将不足以作为主数据库提供数据读写功能,相应的,则设置该仅用作备份的从数据库的角色权重为最低,例如为0,避免将其选为新的主数据库。然后,根据角色权重配置信息选取角色权重最高的第二主数据库或者其它从数据库作为新的第三主数据库,换言之,将机器配置最优的从数据库选取为新的第三主数据库中,以确保主数据库切换后该主从数据的读写性能。
仍以图3为例,图3中的各个从数据库的角色即为角色权重配置信息,从数据库1、从数据库2以及从数据库3的角色权重配置信息分别为候选主库、备份从库以及可选主库,其中,候选主库反映的角色权重最高,可选主库次之,以及备份从库最低,其不能作为新的主库。对应图3,在将从数据库1和从数据库3的数据同步到与临时的第三主数据库(即从数据库2)中的数据一致后,将从数据库1选取为新的第三主数据库。
在本发明一些可选的实施例中,在选取出新的第三主数据库之后,向用户发送主从数据库切换的确认通知,以供用户进行切换确认,例如,通过发送邮件供用户进行确认;响应于用户的确认操作,执行后续数据补全以及配置更新的操作。在这些可选的实施例中,在用户确认后再继续进行后续的切换操作,在网络抖动时,可因用户未执行确认操作而不进行后续的数据补全以及配置更新,防止因网络抖动而导致切换后又不断的发生宕机,以图3为例,在切换为从数据库1后发生宕机,然后切换为从数据库3后又发生宕机。
步骤S240:利用该第一主数据库中的插件,查询该第一主数据库的待同步数据,根据查询结果对该第三主数据库进行数据补全处理。
实际中,可在每个数据库中均部署插件,以便在任一数据库作为主数据库并宕机后,可利用该数据库中的插件对新的主数据库中的数据进行补全处理。
具体地,向该第一主数据库的插件发送数据查询请求,该插件根据该数据查询请求查询第一主数据库的待同步数据,其中,可在数据查询请求中携带经前述主从同步后该第三主数据库的数据同步位置信息,例如,携带数据点10,以便插件查询是否存在第一主数据库的待同步数据,该第一主数据库的待同步数据即为经前述主从同步后,第三主数据库中不存在,而第一主数据库中存在数据;然后,当查询到存在第一主数据的待同步数据后,将该第一主数据库的待同步数据写入到该第三主数据库中;若查询到不存在第一主数据库的待同步数据,则可省去数据补全处理的过程,而执行后续更新配置信息的步骤。通过这种方式,可将临时的第二主数据库未同步到该第三主数据库中的数据,利用插件进行补全,避免数据遗漏。
图4是示出了对应图3的主从数据库的数据补全过程的示意图。如图4所示,在将从数据库1选取为新的第三主数据库后,则主从数据库的拓扑结构变为1主(第三主数据库)2从(从数据库2和从数据库3),经主从同步后该1主2从中的数据均同步到10,数据补全流程如下:1:切换***向第一主数据库的插件发送查询是否存在大于10的数据的查询请求;2:由于第一主数据库中的数据为12,即具有待同步数据11和12,插件将数据11和12返回给切换***;3:切换***将数据11和12写入到第三主数据库中;4:在写入成功后,对主从数据库进行配置更新(下述步骤S250的内容)。
在上述步骤S220至步骤S240中,通过先选取同步进度最快的临时的第二主数据库,然后选取角色权重最高的第三主数据库,进而依次利用主从同步功能和插件实现数据完全同步。而在本发明的另一些实施例中,可首先判断同步进度最快的从数据库是否为角色权重最高的从数据库,若是,则将该同步进度最快的从数据库直接确定为第三主数据库,并利用插件一次性实现数据完全同步,而可省去主从同步的过程,进一步提高针对这种特殊情况的切换效率。
步骤S250:更新切换后的主从数据库的配置信息。
具体地,将配置信息中的主数据库由第一主数据库更新为第三主数据库,并删除第一主数据库的信息。
根据本实施例提供的主从数据库的切换方法,当监控到当前的第一主数据库发生宕机后,从多个从数据库中选取同步进度最快的目标从数据库作为临时的第二主数据库,并利用主从同步功能,将临时的第二主数据库的待同步数据快速的同步到其它从数据库,使其它从数据库中的数据同步到所有从数据库中最新的数据,尽最大可能减少后续利用插件补全的数据量,提高切换效率;以及,在同步完成后,根据角色权重配置信息选取角色权重最高的从数据库作为新的第三主数据库,其中,角色权重配置信息根据机器配置设置,使得每次可以将当前机器配置最高的从数据库选取为新的第三主数据库,保障主数据库的性能;然后,在利用主从同步完成数据同步的基础上,利用插件对第三主数据库中的数据进行补全,以确保新的第三主数据库中的数据与第一主数据库中的数据一致,避免数据遗漏;最后,更新主从数据库的配置,以供业务方根据该配置获取服务。
本发明实施例提供了一种非易失性计算机存储介质,所述计算机存储介质存储有至少一可执行指令,该计算机可执行指令可执行上述任意方法实施例中的主从数据库的切换方法。
可执行指令具体可以用于使得处理器执行以下操作:
监控当前的第一主数据库是否发生宕机;
当监控到所述当前的第一主数据库宕机时,根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库;
利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库;
根据所述临时的第二主数据库和所述其它从数据库的角色权重配置信息,选取新的第三主数据库;
利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理;
更新切换后的主从数据库的配置信息。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
建立与所述第一主数据库以及多个从数据库的连接;
监控是否可与所述第一主数据库联通,若不可联通,则询问所述多个从数据库是否与所述第一主数据库保持连接;
根据所述多个从数据库返回的询问结果判断所述第一主数据库是否发生宕机。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
若所有从数据库均返回未与所述第一主数据库保持连接的询问结果,则判定所述第一主数据库发生宕机。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
根据各个从数据库的数据同步位置信息确定出同步进度最快的目标从数据库;将所述目标从数据库选取为临时的第二主数据库。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
根据角色权重配置信息选取角色权重最高的第二主数据库或者其它从数据库作为新的第三主数据库。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
根据所述多个从数据库的机器配置,为所述多个从数据库设置角色权重配置信息。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
向所述第一主数据库的插件发送数据查询请求,所述插件根据所述数据查询请求查询第一主数据库的待同步数据;
当查询到存在第一主数据库的待同步数据后,将所述第一主数据库的待同步数据写入到所述第三主数据库中。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
向用户发送主从数据库切换的确认通知,以供用户进行切换确认;
响应于用户的确认操作,利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
将配置信息中的主数据库由第一主数据库更新为第三主数据库。
在一种可选的方式中,所述可执行指令进一步使所述处理器执行如下操作:
检测所述主从数据库的主数据库和/或从数据库是否发生更新;
若是,则建立与新增的主数据库和/或从数据库的连接,和/或断开与删除的主数据库和/或从数据库的连接。
在一种可选的方式中,所述主从数据库为mysql数据库。
图5示出了本发明实施例提供的计算设备的结构示意图,本发明具体实施例并不对计算设备的具体实现做限定。
如图5所示,该计算设备可以包括:处理器(processor)502、通信接口(Communications Interface)504、存储器(memory)506、以及通信总线508。
其中:处理器502、通信接口504、以及存储器506通过通信总线508完成相互间的通信。通信接口504,用于与其它设备比如客户端或其它服务器等的网元通信。处理器502,用于执行程序510,具体可以执行上述用于计算设备的主从数据库的切换方法实施例中的相关步骤。
具体地,程序510可以包括程序代码,该程序代码包括计算机操作指令。
处理器502可能是中央处理器CPU,或者是特定集成电路ASIC(ApplicationSpecific Integrated Circuit),或者是被配置成实施本发明实施例的一个或多个集成电路。计算设备包括的一个或多个处理器,可以是同一类型的处理器,如一个或多个CPU;也可以是不同类型的处理器,如一个或多个CPU以及一个或多个ASIC。
存储器506,用于存放程序510。存储器506可能包含高速RAM存储器,也可能还包括非易失性存储器(non-volatile memory),例如至少一个磁盘存储器。
程序510具体可以用于使得处理器502执行以下操作:
监控当前的第一主数据库是否发生宕机;
当监控到所述当前的第一主数据库宕机时,根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库;
利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库;
根据所述临时的第二主数据库和所述其它从数据库的角色权重配置信息,选取新的第三主数据库;
利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理;
更新切换后的主从数据库的配置信息。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
建立与所述第一主数据库以及多个从数据库的连接;
监控是否可与所述第一主数据库联通,若不可联通,则询问所述多个从数据库是否与所述第一主数据库保持连接;
根据所述多个从数据库返回的询问结果判断所述第一主数据库是否发生宕机。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
若所有从数据库均返回未与所述第一主数据库保持连接的询问结果,则判定所述第一主数据库发生宕机。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
根据各个从数据库的数据同步位置信息确定出同步进度最快的目标从数据库;将所述目标从数据库选取为临时的第二主数据库。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
根据角色权重配置信息选取角色权重最高的第二主数据库或者其它从数据库作为新的第三主数据库。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
根据所述多个从数据库的机器配置,为所述多个从数据库设置角色权重配置信息。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
向所述第一主数据库的插件发送数据查询请求,所述插件根据所述数据查询请求查询第一主数据库的待同步数据;
当查询到存在第一主数据库的待同步数据后,将所述第一主数据库的待同步数据写入到所述第三主数据库中。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
向用户发送主从数据库切换的确认通知,以供用户进行切换确认;
响应于用户的确认操作,利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
将配置信息中的主数据库由第一主数据库更新为第三主数据库。
在一种可选的方式中,所述程序510进一步使所述处理器502执行以下操作:
检测所述主从数据库的主数据库和/或从数据库是否发生更新;
若是,则建立与新增的主数据库和/或从数据库的连接,和/或断开与删除的主数据库和/或从数据库的连接。
在一种可选的方式中,所述主从数据库为mysql数据库。
在此提供的算法或显示不与任何特定计算机、虚拟***或者其它设备固有相关。各种通用***也可以与基于在此的示教一起使用。根据上面的描述,构造这类***所要求的结构是显而易见的。此外,本发明实施例也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明实施例的内容,并且上面对特定语言所做的描述是为了披露本发明实施例的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本发明实施例并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明实施例的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明实施例要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的一些或者全部部件的一些或者全部功能。本发明实施例还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明实施例的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明实施例进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明实施例可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。上述实施例中的步骤,除有特殊说明外,不应理解为对执行顺序的限定。
本发明公开了:A1.一种主从数据库的切换方法,包括:
监控当前的第一主数据库是否发生宕机;
当监控到所述当前的第一主数据库宕机时,根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库;
利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库;
根据所述临时的第二主数据库和所述其它从数据库的角色权重配置信息,选取新的第三主数据库;
利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理;
更新切换后的主从数据库的配置信息。
A2.根据A1所述的方法,其中,所述方法还包括:建立与所述第一主数据库以及多个从数据库的连接;
所述监控当前的第一主数据库是否发生宕机进一步包括:
监控是否可与所述第一主数据库联通,若不可联通,则询问所述多个从数据库是否与所述第一主数据库保持连接;
根据所述多个从数据库返回的询问结果判断所述第一主数据库是否发生宕机。
A3.根据A2所述的方法,其中,所述根据所述多个从数据库返回的询问结果判断所述第一主数据库是否发生宕机进一步包括:
若所有从数据库均返回未与所述第一主数据库保持连接的询问结果,则判定所述第一主数据库发生宕机。
A4.根据A1-A3任一项所述的方法,其中,所述根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库进一步包括:
根据各个从数据库的数据同步位置信息确定出同步进度最快的目标从数据库;将所述目标从数据库选取为临时的第二主数据库。
A5.根据A1-A4任一项所述的方法,其中,所述根据所述临时的第二主数据库和所述其它从数据库的角色权重配置信息,选取新的第三主数据库进一步包括:
根据角色权重配置信息选取角色权重最高的第二主数据库或者其它从数据库作为新的第三主数据库。
A6.根据A1-A5任一项所述的方法,其中,所述方法还包括:
根据所述多个从数据库的机器配置,为所述多个从数据库设置角色权重配置信息。
A7.根据A1-A6任一项所述的方法,其中,所述利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理进一步包括:
向所述第一主数据库的插件发送数据查询请求,所述插件根据所述数据查询请求查询第一主数据库的待同步数据;
当查询到存在第一主数据库的待同步数据后,将所述第一主数据库的待同步数据写入到所述第三主数据库中。
A8.根据A1-A7任一项所述的方法,其中,在所述选取新的第三主数据库后,所述方法还包括:
向用户发送主从数据库切换的确认通知,以供用户进行切换确认;
所述利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理具体为:
响应于用户的确认操作,利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理。
A9.根据A1-A8任一项所述的方法,其中,所述更新切换后的主从数据库的配置信息进一步包括:
将配置信息中的主数据库由第一主数据库更新为第三主数据库。
A10.根据A1-A9任一项所述的方法,其中,所述方法还包括:
检测所述主从数据库的主数据库和/或从数据库是否发生更新;
若是,则建立与新增的主数据库和/或从数据库的连接,和/或断开与删除的主数据库和/或从数据库的连接。
A11.根据A1-A10任一项所述的方法,其中,所述主从数据库为mysql数据库。
本发明还公开了:B12.一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;
所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行如A1-A11任一项所述的主从数据库的切换方法对应的操作。
本发明还公开了:B13.一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行如A1-A11任一项所述的主从数据库的切换方法对应的操作。

Claims (10)

1.一种主从数据库的切换方法,包括:
监控当前的第一主数据库是否发生宕机;
当监控到所述当前的第一主数据库宕机时,根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库;
利用主从同步功能,将临时的第二主数据库的待同步数据同步给其它从数据库;
根据所述临时的第二主数据库和所述其它从数据库的角色权重配置信息,选取新的第三主数据库;
利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理;
更新切换后的主从数据库的配置信息。
2.根据权利要求1所述的方法,其中,所述方法还包括:建立与所述第一主数据库以及多个从数据库的连接;
所述监控当前的第一主数据库是否发生宕机进一步包括:
监控是否可与所述第一主数据库联通,若不可联通,则询问所述多个从数据库是否与所述第一主数据库保持连接;
根据所述多个从数据库返回的询问结果判断所述第一主数据库是否发生宕机。
3.根据权利要求2所述的方法,其中,所述根据所述多个从数据库返回的询问结果判断所述第一主数据库是否发生宕机进一步包括:
若所有从数据库均返回未与所述第一主数据库保持连接的询问结果,则判定所述第一主数据库发生宕机。
4.根据权利要求1-3任一项所述的方法,其中,所述根据各个从数据库的数据同步位置信息,从多个从数据库中选取临时的第二主数据库进一步包括:
根据各个从数据库的数据同步位置信息确定出同步进度最快的目标从数据库;将所述目标从数据库选取为临时的第二主数据库。
5.根据权利要求1-4任一项所述的方法,其中,所述根据所述临时的第二主数据库和所述其它从数据库的角色权重配置信息,选取新的第三主数据库进一步包括:
根据角色权重配置信息选取角色权重最高的第二主数据库或者其它从数据库作为新的第三主数据库。
6.根据权利要求1-5任一项所述的方法,其中,所述方法还包括:
根据所述多个从数据库的机器配置,为所述多个从数据库设置角色权重配置信息。
7.根据权利要求1-6任一项所述的方法,其中,所述利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理进一步包括:
向所述第一主数据库的插件发送数据查询请求,所述插件根据所述数据查询请求查询第一主数据库的待同步数据;
当查询到存在第一主数据库的待同步数据后,将所述第一主数据库的待同步数据写入到所述第三主数据库中。
8.根据权利要求1-7任一项所述的方法,其中,在所述选取新的第三主数据库后,所述方法还包括:
向用户发送主从数据库切换的确认通知,以供用户进行切换确认;
所述利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理具体为:
响应于用户的确认操作,利用所述第一主数据库中的插件,查询所述第一主数据库的待同步数据,并根据查询结果对所述第三主数据库进行数据补全处理。
9.一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;
所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行如权利要求1-8任一项所述的主从数据库的切换方法对应的操作。
10.一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行如权利要求1-8任一项所述的主从数据库的切换方法对应的操作。
CN202010887335.5A 2020-08-28 2020-08-28 主从数据库的切换方法、计算设备及存储介质 Active CN112015595B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010887335.5A CN112015595B (zh) 2020-08-28 2020-08-28 主从数据库的切换方法、计算设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010887335.5A CN112015595B (zh) 2020-08-28 2020-08-28 主从数据库的切换方法、计算设备及存储介质

Publications (2)

Publication Number Publication Date
CN112015595A true CN112015595A (zh) 2020-12-01
CN112015595B CN112015595B (zh) 2021-03-02

Family

ID=73502355

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010887335.5A Active CN112015595B (zh) 2020-08-28 2020-08-28 主从数据库的切换方法、计算设备及存储介质

Country Status (1)

Country Link
CN (1) CN112015595B (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112749045A (zh) * 2021-01-11 2021-05-04 深圳市伊欧乐科技有限公司 数据库集群切换方法、设备、存储介质及装置
CN113051248A (zh) * 2021-03-22 2021-06-29 中国工商银行股份有限公司 基于主从数据库的碎片整理方法、装置、设备及存储介质
CN115934428A (zh) * 2023-01-10 2023-04-07 湖南三湘银行股份有限公司 一种mysql数据库的主灾备切换方法、装置及电子设备

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104036043A (zh) * 2014-07-01 2014-09-10 浪潮(北京)电子信息产业有限公司 一种mysql高可用的方法及管理节点
CN104765889A (zh) * 2015-04-30 2015-07-08 北京奇虎科技有限公司 基于数据库高可用框架的切换方法及装置
CN104866556A (zh) * 2015-05-15 2015-08-26 北京奇虎科技有限公司 数据库的故障处理方法、装置和数据库***
CN108038157A (zh) * 2017-12-05 2018-05-15 北京星河星云信息技术有限公司 主从数据库读写方法、***、存储装置和服务器
CN108984569A (zh) * 2017-06-05 2018-12-11 中兴通讯股份有限公司 数据库切换方法、***和计算机可读存储介质
US20180365235A1 (en) * 2014-12-31 2018-12-20 International Business Machines Corporation Scalable distributed data store
CN110413685A (zh) * 2019-04-12 2019-11-05 财付通支付科技有限公司 数据库服务切换方法、装置、可读存储介质和计算机设备
CN110413692A (zh) * 2019-07-30 2019-11-05 中国工商银行股份有限公司 用于数据库集群的数据处理方法和服务器
CN111078463A (zh) * 2018-10-19 2020-04-28 阿里巴巴集团控股有限公司 数据备份的方法、装置和***
CN111200532A (zh) * 2020-01-02 2020-05-26 广州虎牙科技有限公司 数据库集群节点主从切换的方法、装置、设备和介质

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104036043A (zh) * 2014-07-01 2014-09-10 浪潮(北京)电子信息产业有限公司 一种mysql高可用的方法及管理节点
US20180365235A1 (en) * 2014-12-31 2018-12-20 International Business Machines Corporation Scalable distributed data store
CN104765889A (zh) * 2015-04-30 2015-07-08 北京奇虎科技有限公司 基于数据库高可用框架的切换方法及装置
CN104866556A (zh) * 2015-05-15 2015-08-26 北京奇虎科技有限公司 数据库的故障处理方法、装置和数据库***
CN108984569A (zh) * 2017-06-05 2018-12-11 中兴通讯股份有限公司 数据库切换方法、***和计算机可读存储介质
CN108038157A (zh) * 2017-12-05 2018-05-15 北京星河星云信息技术有限公司 主从数据库读写方法、***、存储装置和服务器
CN111078463A (zh) * 2018-10-19 2020-04-28 阿里巴巴集团控股有限公司 数据备份的方法、装置和***
CN110413685A (zh) * 2019-04-12 2019-11-05 财付通支付科技有限公司 数据库服务切换方法、装置、可读存储介质和计算机设备
CN110413692A (zh) * 2019-07-30 2019-11-05 中国工商银行股份有限公司 用于数据库集群的数据处理方法和服务器
CN111200532A (zh) * 2020-01-02 2020-05-26 广州虎牙科技有限公司 数据库集群节点主从切换的方法、装置、设备和介质

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112749045A (zh) * 2021-01-11 2021-05-04 深圳市伊欧乐科技有限公司 数据库集群切换方法、设备、存储介质及装置
CN113051248A (zh) * 2021-03-22 2021-06-29 中国工商银行股份有限公司 基于主从数据库的碎片整理方法、装置、设备及存储介质
CN115934428A (zh) * 2023-01-10 2023-04-07 湖南三湘银行股份有限公司 一种mysql数据库的主灾备切换方法、装置及电子设备
CN115934428B (zh) * 2023-01-10 2023-05-23 湖南三湘银行股份有限公司 一种mysql数据库的主灾备切换方法、装置及电子设备

Also Published As

Publication number Publication date
CN112015595B (zh) 2021-03-02

Similar Documents

Publication Publication Date Title
CN112015595B (zh) 主从数据库的切换方法、计算设备及存储介质
CN109308227B (zh) 故障检测控制方法及相关设备
CN107919977B (zh) 一种基于Paxos协议的在线扩容、在线缩容的方法和装置
CN108762668B (zh) 一种处理写入冲突的方法及装置
CN117056116B (zh) 一种流程管理方法和电子设备
CN111880956A (zh) 一种数据同步方法和装置
CN112052230B (zh) 多机房数据同步方法、计算设备及存储介质
CN108205588B (zh) 基于主从结构的数据同步方法及装置
US11522966B2 (en) Methods, devices and systems for non-disruptive upgrades to a replicated state machine in a distributed computing environment
CN113468143A (zh) 数据迁移方法、***、计算设备及存储介质
WO2021082925A1 (zh) 一种交易处理的方法及装置
CN113055203B (zh) Sdn控制平面的异常恢复方法及装置
CN110781039B (zh) 哨兵进程选举方法及装置
CN117370454A (zh) 数据处理方法
WO2024036829A1 (zh) 一种数据融合方法、装置、设备及存储介质
US10341434B2 (en) Method and system for high availability topology for master-slave data systems with low write traffic
CN111367921A (zh) 数据对象的刷新方法及装置
CN110502460B (zh) 数据处理的方法和节点
CN113806309A (zh) 基于分布式锁的元数据删除方法、***、终端及存储介质
CN113032477A (zh) 基于gtid的长距离数据同步方法、装置及计算设备
CN113254159B (zh) 有状态服务的迁移方法、装置、计算机设备及存储介质
CN111367860A (zh) 文件刷新方法及装置
CN111464580B (zh) 主服务器的选取方法及装置
US11269922B2 (en) Database server, database management method, and storage medium
CN117319507A (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
GR01 Patent grant
GR01 Patent grant