一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

一种数据库访问方法、装置、系统、设备及介质与流程

2022-03-14 04:28:39 来源:中国专利 TAG:


1.本公开涉及数据库技术领域,尤其涉及一种数据库访问方法、装置、系统、设备及介质。


背景技术:

2.数据库是一种按照数据结构来组织、存储和管理数据的仓库。
3.目前,为了防止数据库中数据丢失,可以采用主从架构的多个数据库同步数据。如果主数据库发生故障,需要在多个从数据库中确定一个新的主数据库,由于确定新的主数据库时具有不确定性和延时性,用户不能及时确定新的主数据库,影响用户访问数据库的效率。


技术实现要素:

4.为了解决上述技术问题或者至少部分地解决上述技术问题,本公开提供了一种数据库访问方法、装置、系统、设备及介质。
5.本公开实施例提供了一种数据库访问方法,所述方法应用于代理服务器,包括:
6.接收用户发送的数据库访问请求;
7.基于预先获取的主从变更数据确定主数据库,所述主从变更数据包括从数据库变更为主数据库的标识数据;
8.将所述数据库访问请求转发至所述主数据库,以访问所述主数据库。
9.本公开实施例还提供了一种数据库访问装置,所述装置配置于代理服务器,包括:
10.请求接收模块,用于接收用户发送的数据库访问请求;
11.主数据库确定模块,用于基于预先获取的主从变更数据确定主数据库,所述主从变更数据包括从数据库变更为主数据库的标识数据;
12.访问模块,用于将所述数据库访问请求转发至所述主数据库,以访问所述主数据库。
13.本公开实施例还提供了一种数据库访问系统,所示数据库访问系统包括至少一个代理服务器以及与所述代理服务器连接的数据库,所述代理服务器用于执行如本公开实施例提供的数据库访问方法。
14.本公开实施例还提供了一种电子设备,所述电子设备包括:处理器;用于存储所述处理器可执行指令的存储器;所述处理器,用于从所述存储器中读取所述可执行指令,并执行所述指令以实现如本公开实施例提供的数据库访问方法。
15.本公开实施例还提供了一种计算机可读存储介质,所述存储介质存储有计算机程序,所述计算机程序用于执行如本公开实施例提供的数据库访问方法。
16.本公开实施例提供的技术方案与现有技术相比具有如下优点:本公开实施例提供的数据库访问方案,代理服务器接收用户发送的数据库访问请求,基于预先获取的主从变更数据确定主数据库,主从变更数据包括从数据库变更为主数据库的标识数据,将数据库
访问请求转发至主数据库,以访问主数据库。采用上述技术方案,代理服务器可以及时确定主数据库的变更状况,并将用户的访问请求转发至变更后的主数据库,实时性高,并且提高了数据库访问的效率。
附图说明
17.此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
18.为了更清楚地说明本公开实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,对于本领域普通技术人员而言,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
19.图1为本公开实施例提供的一种数据库访问方法的流程示意图;
20.图2为本公开实施例提供的另一种数据库访问方法的流程示意图;
21.图3为本公开实施例提供的一种数据库访问系统的结构示意图;
22.图4为本公开实施例提供的一种数据库访问装置的结构示意图;
23.图5为本公开实施例提供的一种电子设备的结构示意图。
具体实施方式
24.为了能够更清楚地理解本公开的上述目的、特征和优点,下面将对本公开的方案进行进一步描述。需要说明的是,在不冲突的情况下,本公开的实施例及实施例中的特征可以相互组合。
25.在下面的描述中阐述了很多具体细节以便于充分理解本公开,但本公开还可以采用其他不同于在此描述的方式来实施;显然,说明书中的实施例只是本公开的一部分实施例,而不是全部的实施例。
26.现有技术中,如果主数据库发生故障,代理服务器转发用户的请求给故障的主数据库,当获取到主数据库发送的错误信息以及新的主数据库时,才能将请求转发给新的主数据库,交互过程复杂,获取新的主数据库的方式是被动的方式,无法及时转发请求,影响用户访问数据库的效率。为了解决上述问题,本公开实施例中提供了一种的数据库访问方法。
27.图1为本公开实施例提供的一种数据库访问方法的流程示意图,该方法可以由数据库访问装置执行,其中该装置可以采用软件和/或硬件实现,一般可集成在电子设备中。如图1所示,该方法应用于代理服务器,包括:
28.步骤101、接收用户发送的数据库访问请求。
29.代理服务器(proxy)可以理解为一种访问方式,用户通过代理服务器可以访问数据库,并且可以对访问进行记录。代理服务器可以与至少一个数据库连接,本公开实施例中代理服务器可以与主数据库,和/或,代理服务器可以与至少一个从数据库连接。并且,代理服务器的数量可以根据实际情况进行设定,具体不限。
30.具体的,代理服务器可以接收用户发送的数据库访问请求,并转发该数据库访问请求,实现访问。
31.步骤102、基于预先获取的主从变更数据确定主数据库,主从变更数据包括从数据
库变更为主数据库的标识数据。
32.为了保证数据的安全,本公开实施例采用主从架构的多个数据库存储数据。数据库在数据复制协议的作用下,有一个主(leader)数据库和多个从(follower)数据库,主数据库可以负责提供正常的数据库访问功能,让用户能够操作数据,主数据库同时可以通过数据复制协议将数据复制到从数据库,从数据库上的数据是由主数据库发送过来的,所以从数据库的数据是和主数据库的数据保持一致的。如果主数据库因为故障不能正常使用,则可以在多个从数据库中选举出一个新的主数据库。
33.本公开实施例中,接收用户发送的数据库访问请求之前,还可以包括:获取历史主数据库故障且变更之后发送的主从变更数据,其中,主从变更数据中包括主数据库的数据库标识。其中,主从变更数据是用于对数据库的主从属性变化进行记录的数据,主从变更数据可以包括从数据库变更为主数据库的标识数据和主数据库变更为从数据库的标识数据,其中标识数据可以指数据库标识,也即主从变更数据具体可以存储从数据库变更为主数据库的数据库标识以及主数据库变更为从数据库的数据库标识,本公开实施例中用到主从变更数据中从数据库变更为主数据库的数据库标识,即当前的主数据库的数据库标识。当前的主数据库基于选举算法从历史主数据库变更之前的至少一个历史从数据库中选举确定,其中,选举算法为上述数据复制协议中包括的算法。
34.本公开实施例中,在代理服务器中新增一个学习角色(learner)的功能,使得代理服务器可以作为数据复制协议(raft协议)所在数据复制模块中的一部分,能够实时接收到数据库之间的复制数据中的主从变更数据,及时感知到主数据库的变化。代理服务器虽然作为数据复制模块的一部分,但是不参与选举新的主数据库,避免代理服务器成为新的主数据库。数据复制模块为基于数据复制协议的功能模块,用于实现数据库之间的数据复制和同步。
35.当历史主数据库故障且变更之后,其数据复制模块基于选举算法可以从至少一个历史从数据库中选举确定新的主数据库,即进行主从属性变更,之后数据复制模块可以并将主从变更数据发送至代理服务器。代理服务器可以接收该主从变更数据,并基于主从变更数据中的从数据库变更为主数据库的数据库标识确定主数据库,以备后续数据库访问。
36.步骤103、将数据库访问请求转发至主数据库,以访问主数据库。
37.代理服务器确定主数据库之后,可以将数据库访问请求转发至该主数据库,以实现对主数据库中数据的访问。
38.本公开实施例中,主从变更数据中包括主数据库的地址信息,将数据库访问请求转发至主数据库,以访问主数据库,包括:基于主数据库的地址信息与主数据库建立连接,并将数据库访问请求转发至主数据库,以访问主数据库。其中,主数据库的地址信息可以包括ip地址和端口号等信息。代理服务器基于主数据库的地址信息可以与主数据库建立连接,并且向主数据库转发数据库访问请求,以使用户可以实现对主数据库的访问。
39.本公开实施例提供的数据库访问方案,代理服务器接收用户发送的数据库访问请求,基于预先获取的主从变更数据确定主数据库,主从变更数据包括从数据库变更为主数据库的标识数据,将数据库访问请求转发至主数据库,以访问主数据库。采用上述技术方案,代理服务器可以及时确定主数据库的变更状况,并将用户的访问请求转发至变更后的主数据库,实时性高,并且提高了数据库访问的效率。
40.图2为本公开实施例提供的另一种数据库访问方法的流程示意图,本实施例在上述实施例的基础上,进一步优化了上述数据库访问方法。如图2所示,该方法包括:
41.步骤201、获取历史主数据库故障且变更之后发送的主从变更数据。
42.其中,主从变更数据中包括主数据库的数据库标识。主数据库基于选举算法从历史主数据库变更之前的至少一个历史从数据库中选举确定。
43.步骤202、接收用户发送的数据库访问请求。
44.步骤203、基于预先获取的主从变更数据确定主数据库。
45.主从变更数据包括从数据库变更为主数据库的标识数据。由于主从变更数据库中存储有从数据库变更为主数据库的数据库标识,可以直接确定当前的主数据库。
46.步骤204、将数据库访问请求转发至主数据库,以访问主数据库。
47.具体的,主从变更数据中包括主数据库的地址信息,将数据库访问请求转发至主数据库,以访问主数据库,包括:基于主数据库的地址信息与主数据库建立连接,并将数据库访问请求转发至主数据库,以访问主数据库。其中,主数据库的地址信息可以包括ip地址和端口号等信息。
48.本公开实施例提供的数据库访问方案,代理服务器获取历史主数据库故障且变更之后发送的主从变更数据,接收用户发送的数据库访问请求,基于预先获取的主从变更数据确定主数据库,将数据库访问请求转发至主数据库,以访问主数据库。采用上述技术方案,代理服务器可以及时确定主数据库的变更状况,并将用户的访问请求转发至变更后的主数据库,实时性高,并且提高了数据库访问的效率。
49.图3为本公开实施例提供的一种数据库访问系统的结构示意图,如图3所示,该数据库访问系统包括至少一个代理服务器以及与代理服务器连接的数据库,代理服务器用于执行上述实施例中的数据库访问方法。
50.参见图3,图中示例性的示出了两个从数据库和三个代理服务器,代理服务器41与主数据库11连接,代理服务器42与从数据库21连接,代理服务器43与从数据库31连接。由于对数据库的管理和操作是通过数据库实例实现的,本公开实施例中以一个数据库对应一个数据库实例进行说明,图3中主数据库11可以位于主数据库实例10中,通过主数据库实例10访问,从数据库21可以位于从数据库实例20,从数据库31可以位于从数据库实例30中。数据库实例是用于管理数据库文件的内存结构,可以理解为一系列的系统进程(或线程)和为这些进程(或线程)分配的内存块,数据库实例是用户可以访问的一个独立逻辑概念。
51.主数据库实例10中还可以包括数据复制模块12,从数据库实例20中还可以包括数据复制模块22,从数据库实例中还可以包括数据复制模块32,数据复制模块均基于一致性协议(raft协议)实现数据同步。
52.参见图3,当主数据库实例或主数据库发生故障时,假设各数据复制模块基于选举算法确定的新的主数据库为从数据库21,则各数据复制模块可以将主从变更数据发送至每个代理服务器中;每个代理服务器接收到用户发送的数据库访问请求时,可以直接将数据库访问请求转发至当前的主数据库,即从数据库21。
53.可以理解的是,图3中代理服务器的数量和与数据库的连接关系仅为示例,其他能够实现用户数据库访问的设置方式也可以,例如可以仅设置一个代理服务器,与每个数据库连接。
54.本公开实施例提供的数据库访问系统,代理服务器可以实时获取主从变更数据,接收用户发送的数据库访问请求,基于预先获取的主从变更数据确定主数据库,将数据库访问请求转发至主数据库,以访问主数据库。采用上述技术方案,代理服务器可以及时确定主数据库的变更状况,并将用户的访问请求转发至变更后的主数据库,实时性高,并且提高了数据库访问的效率。
55.图4为本公开实施例提供的一种数据库访问装置的结构示意图;,该装置可由软件和/或硬件实现,一般可集成在电子设备中。如图4所示,该装置配置于代理服务器,包括:
56.请求接收模块301,用于接收用户发送的数据库访问请求;
57.主数据库确定模块302,用于基于预先获取的主从变更数据确定主数据库,所述主从变更数据包括从数据库变更为主数据库的标识数据;
58.访问模块303,用于将所述数据库访问请求转发至所述主数据库,以访问所述主数据库。
59.本公开实施例提供的数据库访问方案,代理服务器接收用户发送的数据库访问请求,基于预先获取的主从变更数据确定主数据库,主从变更数据包括从数据库变更为主数据库的标识数据,将数据库访问请求转发至主数据库,以访问主数据库。采用上述技术方案,代理服务器可以及时确定主数据库的变更状况,并将用户的访问请求转发至变更后的主数据库,实时性高,并且提高了数据库访问的效率。
60.可选的,所述装置还包括主从变更数据获取模块,用于接收用户发送的数据库访问请求之前,
61.获取历史主数据库故障且变更之后发送的主从变更数据,其中,所述主从变更数据中包括所述主数据库的数据库标识。
62.可选的,所述主数据库基于选举算法从所述历史主数据库变更之前的至少一个历史从数据库中选举确定。
63.可选的,所述主从变更数据中包括所述主数据库的地址信息,所述访问模块303具体用于:
64.基于所述主数据库的地址信息与所述主数据库建立连接,并将所述数据库访问请求转发至所述主数据库,以访问所述主数据库。
65.可选的,所述主数据库的地址信息包括ip地址和端口号。
66.可选的,所述代理服务器与所述主数据库连接,和/或,所述代理服务器与至少一个从数据库连接。
67.本公开实施例所提供的数据库访问装置可执行本发明任意实施例所提供的数据库访问方法,具备执行方法相应的功能模块和有益效果。
68.图5为本公开实施例提供的一种电子设备的结构示意图。如图5所示,电子设备400包括一个或多个处理器401和存储器402。
69.处理器401可以是中央处理单元(cpu)或者具有数据处理能力和/或指令执行能力的其他形式的处理单元,并且可以控制电子设备400中的其他组件以执行期望的功能。
70.存储器402可以包括一个或多个计算机程序产品,所述计算机程序产品可以包括各种形式的计算机可读存储介质,例如易失性存储器和/或非易失性存储器。所述易失性存储器例如可以包括随机存取存储器(ram)和/或高速缓冲存储器(cache)等。所述非易失性
存储器例如可以包括只读存储器(rom)、硬盘、闪存等。在所述计算机可读存储介质上可以存储一个或多个计算机程序指令,处理器401可以运行所述程序指令,以实现上文所述的本公开的实施例的数据库访问方法以及/或者其他期望的功能。在所述计算机可读存储介质中还可以存储诸如输入信号、信号分量、噪声分量等各种内容。
71.在一个示例中,电子设备400还可以包括:输入装置403和输出装置404,这些组件通过总线系统和/或其他形式的连接机构(未示出)互连。
72.此外,该输入装置403还可以包括例如键盘、鼠标等等。
73.该输出装置404可以向外部输出各种信息,包括确定出的距离信息、方向信息等。该输出装置404可以包括例如显示器、扬声器、打印机、以及通信网络及其所连接的远程输出设备等等。
74.当然,为了简化,图5中仅示出了该电子设备400中与本公开有关的组件中的一些,省略了诸如总线、输入/输出接口等等的组件。除此之外,根据具体应用情况,电子设备400还可以包括任何其他适当的组件。
75.除了上述方法和设备以外,本公开的实施例还可以是计算机程序产品,其包括计算机程序指令,所述计算机程序指令在被处理器运行时使得所述处理器执行本公开实施例所提供的数据库访问方法。
76.所述计算机程序产品可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例操作的程序代码,所述程序设计语言包括面向对象的程序设计语言,诸如java、c 等,还包括常规的过程式程序设计语言,诸如“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。
77.此外,本公开的实施例还可以是计算机可读存储介质,其上存储有计算机程序指令,所述计算机程序指令在被处理器运行时使得所述处理器执行本公开实施例所提供的数据库访问方法。
78.所述计算机可读存储介质可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以包括但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、光纤、便携式紧凑盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。
79.需要说明的是,在本文中,诸如“第一”和“第二”等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个
……”
限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
80.以上所述仅是本公开的具体实施方式,使本领域技术人员能够理解或实现本公
开。对这些实施例的多种修改对本领域的技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本公开的精神或范围的情况下,在其它实施例中实现。因此,本公开将不会被限制于本文所述的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献