CN105468717B - 数据库操作方法和装置 - Google Patents

数据库操作方法和装置 Download PDF

Info

Publication number
CN105468717B
CN105468717B CN201510811458.XA CN201510811458A CN105468717B CN 105468717 B CN105468717 B CN 105468717B CN 201510811458 A CN201510811458 A CN 201510811458A CN 105468717 B CN105468717 B CN 105468717B
Authority
CN
China
Prior art keywords
database
slave
master
preset
instance
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
CN201510811458.XA
Other languages
English (en)
Other versions
CN105468717A (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.)
Beijing Baidu Netcom Science and Technology Co Ltd
Original Assignee
Beijing Baidu Netcom Science and 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 Beijing Baidu Netcom Science and Technology Co Ltd filed Critical Beijing Baidu Netcom Science and Technology Co Ltd
Priority to CN201510811458.XA priority Critical patent/CN105468717B/zh
Publication of CN105468717A publication Critical patent/CN105468717A/zh
Application granted granted Critical
Publication of CN105468717B publication Critical patent/CN105468717B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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

Abstract

本申请公开了数据库操作方法和装置。该方法的一具体实施方式包括:接收对目标数据库的数据库操作请求,数据库操作请求包括:目标数据库的类型标识、对目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作;对目标数据库执行经确定出的数据库操作。实现了对不同类型的数据库的操作逻辑、操作接口以及操作方法的统一,进而提升了数据库系统的可靠性。

Description

数据库操作方法和装置
技术领域
本申请涉及计算机领域,具体涉及数据库领域,尤其涉及数据库操作方法和装置。
背景技术
随着云计算技术的快速发展,云计算平台提供的云计算服务也越来越丰富。云数据库服务(RDS)是被广泛应用的云计算服务之一。云数据库服务通过将多种类型的数据库部署在云服务器上,以供用户使用不同类型的数据库进行数据存储。
在已知的云数据库系统中,需要针对云服务器上部署的每一个类型的云数据库,分别设置与云数据库的类型对应的数据库操作规程,同时,需要针对每一个类型的数据库分别制定不同的故障检测以及故障修复方案,从而增加了云数据库系统的系统开销,导致云数据库服务的运行效率降低,以及降低云数据库系统的可靠性。
发明内容
本申请提供了数据库操作方法和装置,用于解决上述背景技术部分存在的技术问题。
第一方面,本申请提供了数据库操作方法,该方法包括:接收对目标数据库的数据库操作请求,数据库操作请求包括:目标数据库的类型标识、对目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作;对目标数据库执行经确定出的数据库操作。
第二方面,本申请提供了数据库操作装置,该装置包括:接收单元,配置用于接收对目标数据库的数据库操作请求,数据库操作请求包括:目标数据库的类型标识、对目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;确定单元,配置用于确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作;执行单元,配置用于执行对目标数据库执行经确定出的数据库操作。
本申请提供的数据库操作方法和装置,通过接收对目标数据库的数据库操作请求;确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作;对目标数据库执行经确定出的数据库操作。实现了对不同类型的数据库的操作逻辑、操作接口以及操作方法的统一,进而提升了数据库系统的可靠性。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显:
图1是本申请可以应用于其中的示例性系统架构图;
图2示出了根据本申请的数据库操作方法的一个实施例的流程图;
图3示出了对多个类型的数据库进行统一操作的原理图;
图4示出了根据本申请的数据库操作方法的另一个实施例的流程图;
图5示出了数据库实例的运行状态转换的原理图;
图6示出了对多个类型的数据库进行统一监控的原理图;
图7示出了根据本申请的数据库操作装置的一个实施例的结构示意图;
图8是适于用来实现本申请实施例的终端设备或服务器的计算机系统的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的数据库操作方法或数据库操作装置的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供传输链路的介质。网络104可以包括各种连接类型,例如有线、无线传输链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯应用,例如网络安全类应用、即时通信工具等。
终端设备101、102、103可以是具有显示屏并且支持网络通信的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving Picture ExpertsGroup Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving PictureExperts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上的数据库类应用提供支持的服务器。服务器可以对接收到的数据库操作请求进行处理,并将处理结果(例如数据库中的数据)反馈给终端设备。
应理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
请参考图2,其示出了根据本申请的数据库操作方法的一个实施例的流程200。该方法包括以下步骤:
步骤201,接收对目标数据库的数据库操作请求。
在本实施例中,数据库操作请求包括:目标数据库的类型标识、对目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作。
在本实施例中,可以预先定义适用于对多个类型的数据库进行统一操作的预设数据库操作。例如,可以根据不同类型的数据库均支持创建数据库、删除数据库等类型的操作,预先定义与上述数据库操作的类型对应的预设数据库操作。
在本实施例中,可以预先设置预设数据库操作对应的预设数据库操作接口,通过预设数据库操作接口,调用预设数据库操作。在本实施例中,预设数据库操作可以预先对应于一个操作标识,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作。以多个类型的数据库均支持的数据库启动操作为例,可以预先定义与数据库启动操作这一类型对应的预设数据库操作中的启动操作,该启动操作对应于一个操作标识。由于不同类型的数据库在执行自身的数据库启动操作时,提供不同的调用接口来调用数据库启动操作,因此,在本实施例中,可以预先建立该操作标识与不同类型的数据库提供的数据库启动操作的调用接口的对应关系,从而建立预设数据库中的启动操作与被不同类型的数据库最终执行的数据库启动操作的对应关系。在本实施例中,通过预设数据库操作与被不同类型的数据库最终执行的数据库操作的对应关系,使得当对不同类型的数据库中进行同属于同一操作类型的数据库操作时,可以通过与该操作类型对应的预设数据库操作完成,从而实现利用预设数据库操作对多个类型的数据库的统一操作。
在本实施例的一些可选的实现方式中,目标数据库为运行于云服务器上的云数据库,云服务器运行多个类型的云数据库。在本实施例中,目标数据库可以为运行在云服务器上的云数据库,例如,运行在云服务器上的MySQL云数据库、SQLServer云数据库、Oracle云数据库等类型的云数据库。相应地,可以提供与目标数据库对应的云数据库服务,也可称之为关系型数据库服务(Relational Database Service,RDS),从而使得用户可以利用云数据库服务对云数据库进行操作。
在本实施例的一些可选的实现方式中,预设数据库操作包括以下之一:创建操作、监控操作、修复操作、删除操作、升级操作、扩容操作、主从切换操作。
在本实施例中,创建操作可以用于创建数据库。监控操作可以用于获取数据库运行过程中的参数以及运行状态,该参数可以包括数据库是否可以正常、CPU占有率、磁盘使用率等。修复操作可以用于在数据库发生故障时,对故障进行修复。删除操作可以用于删除数据库。升级操作可以用于对数据库的版本进行升级。扩容操作可以用于扩充数据库的容量。主从切换操作可以用于在主数据库发生故障时,将从数据库切换为主数据库,由从数据库提供数据库服务。主从切换操作还可以用于在对主数据库的升级过程中,由从数据库替换主数据库提供数据库服务,同时,对主数据库进行升级,当主数据库完成升级后,再由升级后的主数据库提供数据库服务。在本实施例中,预设数据库操作还包括用于对数据库进行启动的启动操作、用于对数据库进行重启的重启操作等预设数据库操作。
在本实施例中,可以针对上述预设数据库操作,分别建立上述预设和数据库操作的操作标识与被不同类型的数据库执行的上述类型的数据库操作之间的对应关系,从而基于该对应关系,经由相应地预设数据库操作接口分别执行被不同类型的数据库执行的创建操作、监控操作、修复操作、删除操作、升级操作、扩容操作、主从切换操作、启动操作、重启操作等数据库操作。
步骤202,确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作。
在本实施例中,可以基于预设数据库操作的操作标识与被不同类型的数据库最终执行的数据库操作的对应关系,确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作。以目标数据库为MySQL数据库,对MySQL数据库执行数据库启动操作为例,对MySQL数据库的操作请求中可以包括:MySQL数据库的类型标识、预设数据库操作中预设启动数据库操作的操作标识。可以基于MySQL数据库的类型标识,确定当前操作的数据库类型为MySQL数据库。可以基于预设数据库操作中的启动操作的操作标识与被不同类型的数据库最终执行的数据库启动操作的对应关系,确定出MySQL数据库提供的与数据库启动操作对应的调用接口。
步骤203,对目标数据库执行经确定出的数据库操作。
在本实施例中,在确定出了被目标数据库执行的数据库操作之后,可以对目标数据库执行经确定出的数据库操作。以目标数据库为MySQL数据库,对MySQL数据库进行启动为例,当基于预设数据库操作中的启动操作的操作标识与被不同类型的数据库最终执行的数据库启动操作的对应关系,确定出MySQL数据库提供的与数据库启动操作对应的调用接口时,可以利用该调用接口调用被MySQL数据库执行的数据库启动操作,对MySQL数据库进行启动。
在本实施例的一些可选的实现方式中,预设数据库操作为创建操作,以及对目标数据库执行经确定出的数据库操作包括:分别创建目标数据库对应的主数据库与从数据库,以及分别创建主数据库与从数据库对应的主数据库实例与从数据库实例。
下面以目标数据库为MySQL数据库为例,说明预设数据库操作为创建操作时,对目标数据库的创建过程:可以响应于客户端发送的创建MySQL数据库的数据库操作请求,创建主MySQL数据库以及从MySQL数据库。主MySQL数据库可以将数据的变化同步到从数据库,从MySQL数据库可以处于待命状态。从MySQL数据库可以对主MySQL数据库上的数据进行备份,确保数据不因故障而丢失以及当主MySQL数据库出现故障时,从MySQL数据库可以继续执行由主MySQL数据库执行的数据库操作。在本实施例中,在对主MySQL数据库、从MySQL数据库执行数据库操作时,可以预先创建主MySQL数据库、从MySQL数据库对应的主MySQL数据库实例、从MySQL数据库实例,然后,可以将主MySQL数据库、从MySQL数据库的数据库文件加载到主MySQL数据库实例、从MySQL数据库实例中,在加载完成之后,可以利用主MySQL数据库实例、从MySQL数据库对主MySQL数据库、从MySQL数据库执行数据库操作。
在本实施例的一些可选的实现方式中,预设数据库操作为除创建操作之外的预设数据库操作,以及对目标数据库执行经确定出的数据库操作包括:利用主数据库实例和/或从数据库实例对主数据库和/或从数据库执行除创建操作对应的经确定出的数据库操作之外的经确定出的数据库操作。
在本实施例中,在通过创建操作创建目标数据库之后,可以利用主数据库实例和/或从数据库实例经由预设数据库操作接口对主数据库和/或从数据库执行监控操作、修复操作、删除操作、升级操作、扩容操作、主从切换操作等类型的数据库操作。
请参考图3,其示出了对多个类型的数据库进行统一操作的原理图。在图3中,示出了客户端、数据库操作端、MySQL数据库和SQLServer数据库。MySQL数据库和SQLServer数据库分别对应MySQL数据库实例和SQLServer数据库实例。可以采用VM/Docker对MySQL数据库实例和SQLServer数据库实例进行部署。客户端可以通过在控制台输入与数据库操作对应的指令,发出对MySQL数据库和SQLServer数据库的数据库操作请求。Agent代理应用可以用于将数据库操作请求发送至数据库操作端。数据库操作端可以接收数据库操作请求,利用MySQL数据库实例和SQLServer数据库实例分别对MySQL数据库和SQLServer数据库进行操作。在数据库操作端,设置有预设数据库操作中的监控操作、启动操作、停止操作、修复操作对应的monitor、start、stop、repair接口以及主从转换操作相关联的switchover、failover等预设数据库操作接口。相应地,在TaskScript中配置与预设数据库操作接口对应的被不同类型的数据库执行的数据库操作,例如脚本文件。从而当上述接口被调用时,可以调用相应地脚本文件执行被不同类型的数据库执行的数据库操作。
在本实施例中,可以利用ActiveMQ队列对数据库操作请求进行排序,可以采用以下方式实现ActiveMQ队列:预先为每一个数据库操作预先准备一个队列,当接收到数据库操作请求时,则可以根据数据库操作的类型将数据库操作加入相应地队列中。然后,利用任务管理单元TaskManagement依次对ActiveMQ队列中的数据库操作请求进行处理。
在本实施例中,当同时对MySQL数据库和SQLServer数据库进行数据库操作时,仅需在数据库操作请求中分别加入MySQL数据库和SQLServer数据库的类型的标识,以及预设数据库操作的操作标识,即可经由预设数据库操作接口,分别执行MySQL数据库和SQLServer数据库各自对应的数据库操作,从而实现对不同类型的数据库的统一操作。
在本实施例中,通过对不同类型的数据库进行统一操作,减少了客户端与数据库操作端之间的耦合。一方面,相较于现有技术中的针对每一种类型的数据库,均需在客户端与数据库操作端设置独立的数据库操作规程,减轻了数据库系统的负载。另一方面,相较于现有技术中的当对一个类型的数据库进行配置(例如数据库版本升级)时,由于每一个类型的数据库对应一套独立的数据库操作规程,因此,对数据库服务端中的数据库操作进行更新,需要对客户端行相应地更新。而在本实施例中,由于客户端与数据库操作端的分离,从而仅对数据库操作端进行更新即可,进一步提升数据库系统的可靠性。
在本实施例中,通过接收对目标数据库的数据库操作请求,数据库操作请求包括:目标数据库的类型标识、对目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作;执行经确定出的数据库操作。实现了对不同类型的数据库的操作逻辑、操作接口以及操作方法的统一,进而提升了数据库系统的可靠性。
请参考图4,其示出了根据本申请的数据库操作方法的另一个实施例的流程400。该方法包括以下步骤:
步骤401,接收对目标数据库的数据库操作请求。
在本实施例中,目标数据库可以为运行于云服务器上的云数据库,云服务器运行多个类型的云数据库。
在本实施例中,预设数据库操作包括以下之一:创建操作、监控操作、修复操作、删除操作、升级操作、扩容操作、主从切换操作。
步骤402,确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作。
在本实施例中,可以基于预设数据库操作的操作标识与被不同类型的数据库最终执行的数据库操作的对应关系,确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作。在本实施例中,当预设数据库操作为创建操作时,可以采用以下方式创建目标数据库:分别创建目标数据库对应的主数据库与从数据库,以及分别创建主数据库与从数据库对应的主数据库实例与从数据库实例。在本实施例中,可以利用主数据库实例和/或从数据库实例对主数据库和/或从数据库执行除创建操作对应的经确定出的数据库操作之外的经确定出的数据库操作。
步骤403,创建目标数据库对应的监控线程。
在本实施例中,在分别创建主数据库与从数据库对应的主数据库实例与从数据库实例之后,可以创建目标数据库对应的监控线程;利用监控线程检测主数据库实例以及从数据库实例的运行状态。
在本实施例中,运行状态包括以下之一:启动中状态、已启动状态、操作中状态、关闭中状态、已关闭状态、故障状态。
在本实施例中,可以预先建立表示主数据库实例与从数据库实例的运行状态以及运行状态之间的转换关系。请参考图5,其示出了数据库实例的运行状态转换的原理图。在图5中,示出了Activing(启动中)、Actived(已启动)、Deactiving(关闭中)、Deactived(已关闭)数据库实例状态。应理解,由于对数据库执行的数据库操作是通过数据库实例完成的,因此数据库实例的状态可以相当于数据库的状态。例如,当数据库实例的状态为Actived状态时,则表示数据库可以提供数据库服务。
在本实施例中,当运行状态为故障状态时,可以利用监控线程确定故障状态对应的预设故障类型;执行与预设故障类型对应的修复操作对应的经确定出的数据库操作。监控线程可以通过调用预设数据库操作接口中的monitor接口,获取数据库在运行过程中的参数数据库实例的运行状态。该参数可以包括数据库是否可以正常、CPU占有率、磁盘使用率等。当确定数据库处于故障状态时,则可以确定故障类型,执行与预设故障类型对应的预设数据库操作中的修复操作对应的经确定出的数据库操作,即通过调用预设数据库操作接口中的repair接口,调用与故障类型对应的修复脚本对故障进行修复。
以主数据库与从数据库之间的主从转换操作为例,说明执行故障修复操作的过程:当主数据发生故障时,可以进行主数据库与从数据库之间的切换,即由从数据库替换主数据库,继续执行由主数据库处理的数据库请求,这一过程也可称之为Hot Standby。可以利用HA(High Availability,高可用性)机制执行主数据库与从数据库之间的HotStandby,HA机制的作用为确保主、从数据库数据的一致性,从而减少当主数据库发生故障时,数据库服务中断的次数。
在本实施例中,当运行状态为除故障状态之外的运行状态时,可以在利用主数据库实例和/或从数据库实例对主数据库和/或从数据库执行除创建操作对应的经确定出的数据库操作之外的经确定出的数据库操作之前,利用监控线程基于检测到的主数据库实例和/或从数据库实例的运行状态,确定是否存在与运行状态对应的预设故障类型,预设故障类型为在运行状态下,执行经确定出的数据库操作对应的故障的类型;若是,停止执行经确定出的数据库操作。
在本实施例中,可以预先确定运行状态对应的预设故障类型,该预设故障类型可以为在一些运行状态下,不可进行的数据库操作的类型。然后,可以建立运行状态与预设故障类型的对应关系,在主数据库实例和/或从数据库实例对主数据库和/或从数据库执行读写操作、升级操作、扩容操作等操作之前,利用上述对应关系,判断若进行当前的数据库操作的情况下,是否会发生预设故障。以MySQL数据库为例,监控线程可以预先通过调用预设数据库操作接口中的monitor接口获取主数据库MySQL1的运行状态、从数据库MySQL2的运行状态。当主数据库MySQL1状态运行正常,从数据库MySQL2发生故障时,可以基于预先建立的运行状态与预设故障类型的对应关系,确定此时不能进行由主数据库MySQL1转换到从数据库MySQL2的主从转换操作。进一步地,当判断出存在预设故障时,可以预先通过调用预设数据库操作接口中的repair接口调用相应地修复操作,例如,对从数据库进行重新启动操作,或者先停止对从数据库,然后再对从数据库进行重新启动等操作。从而当执行主数据库MySQL1转换到从数据库MySQL2的主从转换操作时,已经预先修复了预设故障。
下面说明本实施例中的故障监控的方式与现有的数据库系统中的故障监控方式的区别:在现有的数据库系统中,当数据库操作遇到故障时,执行数据库操作的任务会被挂起,此时,再检测故障发生的原因。当接收到客户端发送的对不同类型的数据库的数据库操作请求时,由于每一个类型的数据库均对应于独立的故障检测和修复规程,从而当执行数据库操作的任务被挂起时,无法实现对多个被挂起的线程的统一监控以及对故障进行统一修复,并且,在多个执行数据库操作被挂起的情况下,造成数据库系统的整体运行效率的降低。而在本实例中,监控操作与数据库操作是彼此独立的操作,即监控线程与执行数据库操作的任务是彼此独立的,因此,在本实施例中,可以通过预先获取到的数据库实例的状态,预先确定可能发生的故障,并且当确定可以发生的故障时,及时停止当前所执行的数据库操作以及对故障进行修复。从而避免了在发生故障时,当前数据库操作被挂起,而导致数据库系统的整体运行效率的降低的问题,进一步提升数据库系统的可靠性。
步骤404,对目标数据库执行经确定出的数据库操作。
在本实施例中,在确定出了被目标数据库执行的数据库操作之后,可以对目标数据库执行经确定出的数据库操作。
请参考图6,其示出了对多个类型的数据库进行统一监控的原理图。在图6中,分别示出了客户端、数据库操作端、DBA操作端。主数据库MySQL1以及从数据库MySQL2、用于对主MySQL1数据库以及从数据库MySQL2的运行情况进行监控的监控单元XMaster。
在本实施例中,可以采用VM/Docker对MySQL1数据库实例和MySql2数据库实例进行部署。客户端可以通过在控制台输入与数据库操作对应的指令,发出对主MySQL1数据库以及从数据库MySQL2的数据库操作请求。Agent代理应用可以用于将数据库操作请求发送至数据库操作端。数据库操作端可以接收数据库操作请求,利用MySql1数据库实例和MySql2数据库实例分别对MySql1数据库和MySql2数据库执行数据库操作。
在本实施例中,可以利用ActiveMQ队列对数据库操作请求进行排序,可以采用以下方式实现ActiveMQ队列:预先为每一个数据库操作预先准备一个队列,当接收到数据库操作请求时,则可以根据数据库操作的类型将数据库操作加入相应地队列中。然后,利用任务管理单元TaskManagement依次对ActiveMQ队列中的数据库操作请求进行处理。
在数据库操作端,设置有预设数据库操作中的监控操作、启动操作、停止操作、修复操作对应的monitor、start、stop、repair接口以及主从转换操作相关联的switch、failover等预设数据库操作接口。相应地,在TaskScript中配置与预设数据库操作接口对应的被不同类型的数据库执行的数据库操作,例如脚本文件。从而当上述接口被调用时,可以调用相应地脚本文件执行被不同类型的数据库执行的数据库操作。
在本实施例中,监控单元XMaster可以针对主数据库MySql1实例以及从数据库MySql2实例,创建监控线程,监控线程可以调用预设数据库操作接口中的monitor接口获取到主数据库MySql1实例以及从数据库MySql2实例的启动中、已启动、可操作、关闭中、已关闭等运行状态以及主数据库MySql1、从数据库MySql2是否正常、CPU占有率、磁盘使用率等参数。此外,还可以通过数据库系统中的元数据单元MetaData获取数据库实例的属性,例如数据库实例对应的用户标识,以向相应地数据库实例发送数据库操作请求。
在本实施例中,可以基于预先建立的运行状态对应与预设故障类型的对应关系,该预设故障类型可以为在一些运行状态下,不可进行的数据库操作的类型,判断主数据库MySql1实例以及从数据库MySql2实例当前执行的数据库操作是否存在预设故障,若存在预设故障,则可以停止当前所执行的数据库操作,以及通过故障修复脚本对预设故障进行修复。
在本实施例中,通过设置数据库实例对应的监控线程,减少了DBA操作端、数据库操作端、客户端的之间的耦合,仅需在数据库操作请求中加入数据库类型的标识,以及预设数据库操作的操作标识,即可分别在数据库操作端执行多个类型的数据库各自对应的数据库操作。进一步地,在对不同类型的数据库的统一操作过程中,对数据库的实例的运行状态进行监控,从而预先检查出是否存在与当前执行的数据库操作的故障,当存在故障时,利用修复脚本对故障进行修复。可以在DBA操作端,灵活地配置监控操作以及灵活地配置故障修复脚本。从而,在对不同类型的数据库的操作逻辑、操作接口以及操作方法进行统一的基础上,进一步实现了对不同类型的数据库的统一监控和故障修复,进一步提升了数据库系统的可靠性。
请参考图7,其示出了根据本申请的数据库操作装置的结构示意图。装置700包括:接收单元701,确定单元702,执行单元703。接收单元701配置用于接收对目标数据库的数据库操作请求,数据库操作请求包括:目标数据库的类型标识、对目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;确定单元702配置用于确定出由类型标识指示的类型的数据库执行的、与操作标识对应的数据库操作;执行单元703配置用于对目标数据库执行经确定出的数据库操作。
在本实施例的一些可选的实现方式中,目标数据库为运行于云服务器上的云数据库,云服务器运行多个类型的云数据库。
在本实施例的一些可选的实现方式中,预设数据库操作包括以下之一:创建操作、监控操作、修复操作、删除操作、升级操作、扩容操作、主从切换操作。
在本实施例的一些可选的实现方式中,执行单元703包括:第一执行子单元(未示出),配置用于当预设数据库操作为创建操作时,分别创建目标数据库对应的主数据库与从数据库,以及分别创建主数据库与从数据库对应的主数据库实例与从数据库实例。
在本实施例的一些可选的实现方式中,执行单元703包括:第二执行子单元(未示出),配置用于当预设数据库操作为除创建操作之外的预设数据库操作时,利用主数据库实例和/或从数据库实例对主数据库和/或从数据库执行除创建操作对应的经确定出的数据库操作之外的经确定出的数据库操作。
在本实施例的一些可选的实现方式中,装置700还包括:监控线程创建单元(未示出),配置用于创建目标数据库对应的监控线程;运行状态检测单元(未示出),配置用于利用监控线程检测主数据库实例以及从数据库实例的运行状态。
在本实施例的一些可选的实现方式中,运行状态包括以下之一:启动中状态、已启动状态、操作中状态、关闭中状态、已关闭状态、故障状态。
在本实施例的一些可选的实现方式中,装置700还包括:第一故障检测单元(未示出),配置用于当运行状态为故障状态时,利用监控线程确定故障状态对应的预设故障类型;第一故障处理单元(未示出),执行与预设故障类型对应的修复操作对应的经确定出的数据库操作。
在本实施例的一些可选的实现方式中,装置700还包括:第二故障检测单元(未示出),配置用于当运行状态为除故障状态之外的运行状态时,在利用主数据库实例和/或从数据库实例对主数据库和/或从数据库执行除创建操作对应的经确定出的数据库操作之外的经确定出的数据库操作之前,利用监控线程基于检测到的主数据库实例和/或从数据库实例的运行状态,确定是否存在与运行状态对应的预设故障类型,预设故障类型为在运行状态下,执行经确定出的数据库操作对应的故障的类型;第二故障处理单元(未示出),配置用于停止执行经确定出的数据库操作。
图8示出了适于用来实现本申请实施例的终端设备或服务器的计算机系统的结构示意图。如图8所示,计算机系统800包括中央处理单元(CPU)801,其可以根据存储在只读存储器(ROM)802中的程序或者从存储部分808加载到随机访问存储器(RAM)803中的程序而执行各种适当的动作和处理。在RAM 803中,还存储有系统800操作所需的各种程序和数据。CPU 801、ROM 802以及RAM 803通过总线804彼此相连。输入/输出(I/O)接口805也连接至总线804。
以下部件连接至I/O接口805:包括键盘、鼠标等的输入部分806;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分807;包括硬盘等的存储部分808;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分809。通信部分809经由诸如因特网的网络执行通信处理。驱动器810也根据需要连接至I/O接口805。可拆卸介质811,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器810上,以便于从其上读出的计算机程序根据需要被安装入存储部分808。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括有形地包含在机器可读介质上的计算机程序,所述计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分809从网络上被下载和安装,和/或从可拆卸介质811被安装。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,所述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
作为另一方面,本申请还提供了一种非易失性计算机存储介质,该非易失性计算机存储介质可以是上述实施例中所述装置中所包含的非易失性计算机存储介质;也可以是单独存在,未装配入终端中的非易失性计算机存储介质。上述非易失性计算机存储介质存储有一个或者多个程序,当所述一个或者多个程序被一个设备执行时,使得所述设备:接收对目标数据库的数据库操作请求,所述数据库操作请求包括:所述目标数据库的类型标识、对所述目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;确定出由所述类型标识指示的类型的数据库执行的、与所述操作标识对应的数据库操作;对目标数据库执行经确定出的数据库操作。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离所述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。

Claims (14)

1.一种数据库操作方法,其特征在于,所述方法包括:
接收对目标数据库的数据库操作请求,所述数据库操作请求包括:所述目标数据库的类型标识、对所述目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;
确定出由所述类型标识指示的类型的数据库执行的、与所述操作标识对应的数据库操作;
对目标数据库执行经确定出的数据库操作;
其中,所述方法还包括:在利用对应于目标数据库对应的主数据库的主数据库实例和/或对应于目标数据库对应的从数据库的从数据库实例对主数据库和/或从数据库执行除创建操作对应的经确定出的数据库操作之外的经确定出的数据库操作之前,利用监控线程基于检测到的主数据库实例和/或从数据库实例的除故障状态之外的运行状态,确定是否存在与所述运行状态对应的预设故障类型,所述预设故障类型为在所述运行状态下,执行所述经确定出的数据库操作对应的故障的类型,所述预设故障类型为在所述运行状态下不可进行的数据库操作的类型;若是,停止执行所述经确定出的数据库操作,其中,所述运行状态包括以下之一:启动中状态、已启动状态、操作中状态、关闭中状态、已关闭状态、故障状态。
2.根据权利要求1所述的方法,其特征在于,所述目标数据库为运行于云服务器上的云数据库,所述云服务器运行多个类型的云数据库。
3.根据权利要求1-2之一所述的方法,其特征在于,所述预设数据库操作包括以下之一:创建操作、监控操作、修复操作、删除操作、升级操作、扩容操作、主从切换操作。
4.根据权利要求3所述的方法,其特征在于,所述预设数据库操作为创建操作;以及
所述对目标数据库执行经确定出的数据库操作包括:
分别创建所述目标数据库对应的主数据库与从数据库,以及分别创建所述主数据库与从数据库对应的主数据库实例与从数据库实例。
5.根据权利要求4所述的方法,其特征在于,所述预设数据库操作为除所述创建操作之外的预设数据库操作;以及
所述对目标数据库执行经确定出的数据库操作包括:
利用所述主数据库实例和/或从数据库实例对所述主数据库和/或从数据库执行除创建操作对应的所述经确定出的数据库操作之外的所述经确定出的数据库操作。
6.根据权利要求5所述的方法,其特征在于,所述方法还包括:
创建所述目标数据库对应的监控线程;
利用所述监控线程检测所述主数据库实例以及从数据库实例的运行状态。
7.根据权利要求6所述的方法,其特征在于,所述运行状态为故障状态;以及
所述方法还包括:
利用所述监控线程确定所述故障状态对应的预设故障类型;
执行与所述预设故障类型对应的所述修复操作对应的所述经确定出的数据库操作。
8.一种数据库操作装置,其特征在于,所述装置包括:
接收单元,配置用于接收对目标数据库的数据库操作请求,所述数据库操作请求包括:所述目标数据库的类型标识、对所述目标数据库进行的预设数据库操作的操作标识,其中,每一个操作标识预设为对应多个分别由不同类型的数据库执行的数据库操作;
确定单元,配置用于确定出由所述类型标识指示的类型的数据库执行的、与所述操作标识对应的数据库操作;
执行单元,配置用于对目标数据库执行经确定出的数据库操作;
第二故障检测单元,配置用于在利用对应于目标数据库对应的主数据库的主数据库实例和/或对应于目标数据库对应的从数据库的从数据库实例对所述主数据库和/或从数据库执行除创建操作对应的经确定出的数据库操作之外的经确定出的数据库操作之前,利用监控线程基于检测到的所述主数据库实例和/或从数据库实例的除故障状态之外的运行状态,确定是否存在与所述运行状态对应的预设故障类型,所述预设故障类型为在所述运行状态下,执行所述经确定出的数据库操作对应的故障的类型,所述预设故障类型为在所述运行状态下不可进行的数据库操作的类型,其中,所述运行状态包括以下之一:启动中状态、已启动状态、操作中状态、关闭中状态、已关闭状态、故障状态;
第二故障处理单元,配置用于停止执行所述经确定出的数据库操作。
9.根据权利要求8所述的装置,其特征在于,所述目标数据库为运行于云服务器上的云数据库,所述云服务器运行多个类型的云数据库。
10.根据权利要求8-9之一所述的装置,其特征在于,所述预设数据库操作包括以下之一:创建操作、监控操作、修复操作、删除操作、升级操作、扩容操作、主从切换操作。
11.根据权利要求10所述的装置,其特征在于,所述执行单元包括:
第一执行子单元,配置用于当预设数据库操作为创建操作时,分别创建所述目标数据库对应的主数据库与从数据库,以及分别创建所述主数据库与从数据库对应的主数据库实例与从数据库实例。
12.根据权利要求11所述的装置,其特征在于,所述执行单元包括:
第二执行子单元,配置用于当所述预设数据库操作为除所述创建操作之外的预设数据库操作时,利用所述主数据库实例和/或从数据库实例对所述主数据库和/或从数据库执行除创建操作对应的所述经确定出的数据库操作之外的所述经确定出的数据库操作。
13.根据权利要求12所述的装置,其特征在于,所述装置还包括:
监控线程创建单元,配置用于创建所述目标数据库对应的监控线程;
运行状态检测单元,配置用于利用所述监控线程检测所述主数据库实例以及从数据库实例的运行状态。
14.根据权利要求13所述的装置,其特征在于,所述装置还包括:
第一故障检测单元,配置用于当运行状态为故障状态时,利用所述监控线程确定所述故障状态对应的预设故障类型;
第一故障处理单元,配置用于执行与所述预设故障类型对应的所述修复操作对应的所述经确定出的数据库操作。
CN201510811458.XA 2015-11-20 2015-11-20 数据库操作方法和装置 Active CN105468717B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510811458.XA CN105468717B (zh) 2015-11-20 2015-11-20 数据库操作方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510811458.XA CN105468717B (zh) 2015-11-20 2015-11-20 数据库操作方法和装置

Publications (2)

Publication Number Publication Date
CN105468717A CN105468717A (zh) 2016-04-06
CN105468717B true CN105468717B (zh) 2020-11-10

Family

ID=55606418

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510811458.XA Active CN105468717B (zh) 2015-11-20 2015-11-20 数据库操作方法和装置

Country Status (1)

Country Link
CN (1) CN105468717B (zh)

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106021370A (zh) * 2016-05-11 2016-10-12 智者四海(北京)技术有限公司 内存数据库实例的管理方法及装置
CN107172122A (zh) * 2017-03-31 2017-09-15 北京奇艺世纪科技有限公司 一种异常处理方法及装置
CN107169032B (zh) * 2017-04-17 2020-06-23 北京五八信息技术有限公司 数据库操作方法及数据库服务器
CN107066354B (zh) * 2017-04-18 2021-01-05 中国银联股份有限公司 一种数据库的切换方法、主服务器以及从服务器
CN108009239B (zh) * 2017-11-29 2020-08-04 杭州有赞科技有限公司 数据库访问方法及系统
CN110109983B (zh) * 2017-12-29 2021-11-09 北京京东尚科信息技术有限公司 一种操作Redis数据库的方法和装置
CN108763370A (zh) * 2018-05-17 2018-11-06 杭州安恒信息技术股份有限公司 一种基于docker环境的数据库高可用实现方法
CN110458000A (zh) * 2019-06-28 2019-11-15 安徽四创电子股份有限公司 一种基于docker的视频车辆识别方法
CN110543325A (zh) * 2019-08-15 2019-12-06 中国银行股份有限公司 数据处理方法及装置
CN110515924B (zh) * 2019-08-15 2023-12-12 上海南燕信息技术有限公司 数据库操作逻辑校验方法、装置、设备及可读存储介质
CN111209130B (zh) * 2019-12-27 2023-12-29 中国建设银行股份有限公司 基于MySQL主从复制集群的故障处理方法、系统、设备和介质
CN111611241A (zh) * 2020-04-29 2020-09-01 平安科技(深圳)有限公司 一种字典数据操作方法、装置、可读存储介质及终端设备
CN113590635A (zh) * 2021-08-23 2021-11-02 中国银行股份有限公司 海外多银行的数据分析系统及方法

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1963821A (zh) * 2006-12-05 2007-05-16 华为技术有限公司 一种实现数据库访问的方法、系统和装置
TWI323016B (en) * 2006-12-25 2010-04-01 Ind Tech Res Inst Real-time fault detection and classification system in use with a semiconductor fabrication process
CN100456237C (zh) * 2007-01-31 2009-01-28 华为技术有限公司 数据库访问方法和装置
KR20090012467A (ko) * 2007-07-30 2009-02-04 한국과학기술정보연구원 Uri 데이터베이스를 이용한 통합 검색 시스템 및 방법
CN100555288C (zh) * 2007-11-21 2009-10-28 金蝶软件(中国)有限公司 一种访问不同类型数据库的方法和系统
CN101645074A (zh) * 2009-09-07 2010-02-10 浪潮集团山东通用软件有限公司 一种访问不同类型关系型数据库的方法
CN102193922B (zh) * 2010-03-04 2013-07-24 杭州华三通信技术有限公司 一种对数据库进行访问的方法和装置
CN103716356B (zh) * 2012-10-09 2018-02-27 三亚中兴软件有限责任公司 基于web的存储过程操作方法、装置和系统
US9235464B2 (en) * 2012-10-16 2016-01-12 Microsoft Technology Licensing, Llc Smart error recovery for database applications
CN103853803B (zh) * 2013-06-26 2017-04-19 上海携程商务有限公司 数据库的配置文件的封装方法和操作方法及其操作装置

Also Published As

Publication number Publication date
CN105468717A (zh) 2016-04-06

Similar Documents

Publication Publication Date Title
CN105468717B (zh) 数据库操作方法和装置
CN110389900B (zh) 一种分布式数据库集群测试方法、装置及存储介质
US10152382B2 (en) Method and system for monitoring virtual machine cluster
US9960963B2 (en) Dynamic client fail-over during a rolling patch installation based on temporal server conditions
CN107526659B (zh) 用于失效备援的方法和设备
US10341199B2 (en) State synchronization in a service environment
US9940598B2 (en) Apparatus and method for controlling execution workflows
CN106897095B (zh) 应用程序热修复的方法、装置、可读存储介质和计算设备
CN110225078B (zh) 一种应用服务更新方法、系统及终端设备
CN105159795A (zh) 数据同步方法、装置和系统
CN107453932B (zh) 一种分布式存储系统管理方法及其装置
CN113312153B (zh) 一种集群部署方法、装置、电子设备及存储介质
WO2019100589A1 (zh) 虚拟机快速扩容方法、装置、设备以及存储介质
WO2021120968A1 (zh) 一种服务器扩容方法及扩容系统
CN112434008A (zh) 分布式数据库升级方法、设备及介质
CN109828830B (zh) 用于管理容器的方法和装置
CN113434180B (zh) 应用的数据处理方法、装置、服务器和存储介质
KR20170045981A (ko) 소프트웨어를 포함한 시스템 및 이의 무중단 업그레이드 방법
CN110620798A (zh) Ftp连接的控制方法、系统、设备和存储介质
CN101251815A (zh) 用于恢复计算系统的系统和方法
CN112751693B (zh) 分布式存储系统的数据处理方法、装置及电子设备
CN112181942A (zh) 时序数据库系统和数据处理方法及装置
CN110445628B (zh) 基于nginx的服务器及其部署、监控的方法和装置
CN112579247A (zh) 确定任务状态的方法和装置
CN113872808B (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
GR01 Patent grant
GR01 Patent grant