数据传输方法及相关设备与流程

文档序号:18160988发布日期:2019-07-13 09:19阅读:242来源:国知局
数据传输方法及相关设备与流程

本申请涉及服务器信息技术领域,具体涉及一种数据传输方法及相关设备。



背景技术:

随着社会不断的进步,互联网技术的发展,越来越多的业务由线下办理转由线上办理。银行服务业是日常生活中必不可少的一环,银行服务业采取线上办理后极大的方便了人们的生活,使用户得以在线上办理查询余额、转账和借贷等业务。随着业务办理便捷性的提升,金融消费模式的丰富,越来越多的用户选择使用线上办理业务,且因用户线上办理业务的时间较为随机,容易导致银行服务器短时间内数据传输负荷过高,数据处理效率低下,服务器拥堵等情况的发生。



技术实现要素:

本申请实施例提供了一种数据传输方法及相关设备,以期保证银行服务器在数据传输过程中重要信息的安全性,提高银行服务器的数据传输效率,进而加速银行服务器的数据处理效率。

第一方面,本申请实施例提供一种数据传输方法,应用于银行服务器,包括:

获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;

获取所述第一数据库的数据库连接池的状态信息;

根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。

第二方面,本申请实施例提供一种数据传输装置,包括处理单元和通信单元,其中,

所述处理单元用于,获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;以及通过所述通信单元获取所述第一数据库的数据库连接池的状态信息;以及根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。

第三方面,本申请实施例提供一种服务器,包括处理器、存储器、通信接口以及一个或多个程序,其中,上述一个或多个程序被存储在上述存储器中,并且被配置由上述处理器执行,上述程序包括用于执行本申请实施例第一方面任一方法中的步骤的指令。

第四方面,本申请实施例提供了一种计算机可读存储介质,其中,上述计算机可读存储介质存储用于电子数据交换的计算机程序,其中,上述计算机程序使得计算机执行如本申请实施例第一方面任一方法中所描述的部分或全部步骤。

第五方面,本申请实施例提供了一种计算机程序产品,其中,上述计算机程序产品包括存储了计算机程序的非瞬时性计算机可读存储介质,上述计算机程序可操作来使计算机执行如本申请实施例第一方面任一方法中所描述的部分或全部步骤。该计算机程序产品可以为一个软件安装包。

可以看出,本申请实施例中,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;获取所述第一数据库的数据库连接池的状态信息;根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。可见,银行服务器可根据当前接收到的针对第一数据库的数据传输请求的数量和第一数据库的数据库连接池的状态动态调整数据传输策略以便于快速有序的从第一数据库录入和/或读取数据传输请求中需要的信息,达到了加速数据传输的效果,进而加快了银行服务器的数据处理效率。

附图说明

为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。

图1是本申请实施例提供的一种数据传输方法的示意图;

图2是本申请实施例提供了一种数据传输方法的流程示意图;

图3是本申请实施例提供的另一种数据传输方法的流程示意图;

图4是本申请实施例提供的另一种数据传输方法的流程示意图;

图5是本申请实施例提供的一种服务器的结构示意图;

图6是本申请实施例提供的一种数据传输方法装置的功能单元组成框图。

具体实施方式

为了使本技术领域的人员更好地理解本申请方案,下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。

本申请的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别不同对象,而不是用于描述特定顺序。此外,术语“包括”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可选地还包括没有列出的步骤或单元,或可选地还包括对于这些过程、方法、产品或设备固有的其他步骤或单元。

在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其它实施例相结合。

本申请实施例所涉及到的服务器可以包括各种具有无线通信功能的手持设备、车载设备、可穿戴设备、计算设备或连接到无线调制解调器的其他处理设备,以及各种形式的用户设备(userequipment,ue),移动台(mobilestation,ms),终端设备(terminaldevice)等等。

如图1所示,图1是本申请实施例提供的一种数据传输方法的示意图。

图1中包括:银行服务器110,数据库连接池120,数据库130。其中,数据库连接池120设置有已使用连接池121和空闲连接池122。其中,数据库连接池120中的未被使用的线程在空闲连接池122中,已经使用的线程在已使用连接池121中。当银行服务器110接收到针对数据库130的至少一个数据传输请求时,则获取数据库连接池120的状态信息;若检测到空闲连接池122中存在线程且存在的线程数大于至少一个数据传输请求的数量时,直接使用空闲连接池122中的线程,确定线程与数据传输请求之间的对应关系,并将使用了的线程放入已使用连接池121;若检测到空闲连接池122中存在线程且存在的线程数小于至少一个数据传输请求的数量时,则确定至少一个数据传输请求的优先级序列,根据优先级序列由前至后依次确定与空闲连接池122中的线程之间的对应关系,并检测数据库连接池120的线程是否达到最大线程阈值;若是,则当检测到空闲连接池122中出现线程时按照优先级序列依次确定至少一个数据传输请求中剩余的数据传输请求与线程之间的对应关系;若否,则建立至少一个属于空闲连接池122中的线程使得数据库连接池的线程数达到最大值;并根据优先级序列确定新建立的线程与至少一个数据传输请求中剩余的数据传输请求之间的对应关系,并在检测到空闲连接池122中出现线程时根据优先级序列依次确定至少一个数据传输请求中剩余的数据传输请求与线程之间的对应关系。

本申请提出一种数据传输方法,下面对本申请实施例进行详细介绍。

请参阅图2,图2是本申请实施例提供了一种数据传输方法的流程示意图,应用于银行服务器。如图所示,本数据传输方法包括:

步骤201,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量。

其中,第一数据库可以是银行服务器的一个组成部分,也可以是与银行服务器通信连接的外部数据库。数据传输请求是银行服务器从与银行服务器通信连接的电子设备发送的数据请求信息中提取出来的信息。

步骤202,所述银行服务器获取所述第一数据库的数据库连接池的状态信息。

其中,第一数据库设置有数据库连接池,数据库连接池设置有最小线程连接数和最大线程连接数。银行服务器可根据当前的数据传输数量以及预估当前时间点之后的一段时间的数据传输请求的数量来调整数据库连接池中线程的数量;线程的浮动区间在最小线程连接数和最大线程连接数之间。

步骤203,所述银行服务器根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。

可以看出,本申请实施例中,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;获取所述第一数据库的数据库连接池的状态信息;根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。可见,银行服务器可根据当前接收到的针对第一数据库的数据传输请求的数量和第一数据库的数据库连接池的状态动态调整数据传输策略以便于快速有序的从第一数据库录入和/或读取数据传输请求中需要的信息,达到了加速数据传输的效果,进而加快了银行服务器的数据处理效率。

在一个可能的示例中,所述数据库连接池包括空闲连接池和已使用连接池;所述状态信息包括所述空闲连接池中的线程的第一数量和已使用连接池的线程的第二数量;所述银行服务器根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作,包括:判断所述至少一个数据传输请求的数量是否大于所述第一数量;若是,则确定所述至少一个数据传输请求的优先级序列;从所述优先级序列中筛选出前第一数量位的数据传输请求,确定所述空闲连接池中的线程和所述前第一数量位的数据传输请求之间的对应关系;将所述空闲连接池中的线程放入所述已使用连接池。

其中,数据库连接池中使用了的线程在已使用连接池中,未使用的线程在空闲连接池中;当已使用连接池中的线程被释放时,将被数据库连接池自动放入空闲连接池;当空闲连接池中的线程被使用时,将被数据库连接池自动放入已使用连接池。

举例来说,若当前空闲连接池的线程数为500,而数据传输请求的数量为400,则银行服务器直接使用数据库连接池中的空闲连接池中的400个线程。若当前空闲连接池的线程数为500,而数据传输请求的数量为600,则银行服务器对600个数据传输请求进行分析,生成600个数据传输请求的优先级序列,筛选出优先级序列位于前500位的数据传输请求;确定空闲连接池中500个线程和优先级序列位于前500位的数据传输请求之间的对应关系;之后将500个属于空闲连接池的线程放入已使用连接池。

可见,本示例中,银行服务器可根据当前数据库连接池中的线程数和当前数据传输请求的数量来灵活的调整数据传输的配置方案,提高了银行服务器的智能性;同时,在空闲连接池中的线程不够用的时候可生成数据传输请求的优先级确保及时的完成重要程度高且紧急的数据传输请求,且使银行服务器在进行数据传输时更加有序,加快了数据传输的效率。

在一个可能的示例中,所述银行服务器确定所述至少一个数据传输请求的优先级序列,包括:获取所述至少一个数据传输请求中每个数据传输请求针对的目标业务类型;以所述目标业务类型为查询标识,查询第一预设映射关系,获取所述目标业务类型对应的安全等级,所述第一预设映射关系包括业务类型和安全等级之间的对应关系;根据所述每个数据传输请求针对的所述目标业务类型和所述目标业务类型对应的所述安全等级确定所述每个数据传输请求关联的安全等级;根据所述每个数据传输请求关联的安全等级确定所述至少一个数据传输请求的优先级序列。

其中,业务类型和安全等级之间的对应关系是预先设定的;设定方法可以是根据当前用户办理的业务是信息注册或信息修改,转账、存取钱、买理财产品等业务类型来设定的;信息注册和信息修改等业务不涉及资金的转入与转出,因此安全等级普遍较低;但同样是信息注册和信息修改若注册的信息关联企业的信息则安全等级相对较高,如办理的业务是企业信息修改,则安全等级高于个人信息修改的安全等级;同样,对理财产品、转账、存取钱等业务将根据不同的金额数值确定相关的安全等级。

可见,本示例中,银行服务器可根据不同的业务类型确定不同的安全等级,进而优先处理安全等级较高的数据传输请求,在资源有限的条件下减小了重要信息泄漏的风险,提高了银行服务器中重要数据的安全性。

可选的,银行服务器可结合业务类型的具体特性来确定至少一个数据传输请求的优先级序列。银行服务器可根据业务类型的响应时间、业务类型和额度确定至少一个数据传输请求的优先级序列。具体的,银行服务器获取至少一个数据传输请求针对的业务类型,根据业务类型查询预设对应关系,获取业务类型对应的响应时间,根据响应时间将至少一个数据传输请求划分为及时响应业务、1小时内需响应的业务、1天内需响应的业务和响应时间大于1天的业务。其中,及时响应业务的响应时间系数为1、1小时内需响应的业务的响应时间系数为0.8、1天内需响应的业务的响应时间系数为0.5和响应时间大于1天的业务的响应时间系数为0.3。同时业务类型划分为三大类,分别为信息注册/修改类,资金转入/转出类和理财产品类,设置的理财产品的业务系数为1,资金转入/转出类业务系数为0.7,信息注册/修改类业务类型业务系数为0.2。同时获取至少一个数据传输请求中每个数据传输请求涉及的金额值,确定涉及金额除0以外最小的金额为第一预设金额值,涉及金额最大的金额为第二预设金额值;确定第一差值=第二预设金额值-第一预设金额值。根据上述信息计算至少一个数据传输请求中每个数据传输请求的优先级分数,具体计算公式为:优先级分数=100*响应时间系数*0.4+100*业务系数*0.2+100*(至少一个数据传输请求涉及的金额-第一预设金额)*0.4/第一差值。根据优先级分数由高到低确定至少一个数据传输请求的优先级序列由前至后的顺序。

在一个可能的示例中,所述银行服务器根据所述每个数据传输请求关联的安全等级确定所述至少一个数据传输请求的优先级序列之后,所述方法还包括:检测到所述优先级序列中存在序列位置相同的至少两个数据传输请求;获取所述至少两个数据传输请求中每个数据传输请求关联的账户信息;以所述账户信息为查询标识,查询第二预设映射关系,获取所述账户信息对应的账户类别,所述第二预设映射关系包括账户信息和账户类别之间的对应关系,所述账户类别包括个人账户和企业账户,所述企业账户的优先级大于所述个人账户的优先级;根据所述账户类别确定所述至少两个数据传输请求的优先级;根据所述至少两个数据传输请求的优先级更新所述优先级序列。

其中,根据所述至少两个数据传输请求的优先级更新所述优先级序列后优先级序列中除至少两个数据传输请求在优先级序列中的位置发生变化外其他数据传输请求在优先级序列中的位置不变。

可见,本示例中,银行服务器对于优先级序列中排序处于同一位置的数据传输请求根据账户信息进行重新排序,以便于银行服务器根据优先级序列有序的完成数据传输请求,加快了数据传输的效率,提高了银行服务器的智能性。

在一个可能的示例中,所述银行服务器将所述空闲连接池中的线程放入所述已使用连接池之后,所述方法还包括:判断所述至少一个数据传输请求的数量和所述第二数量之和是否大于所述数据库连接池的最大线程阈值;若否,确定所述至少一个数据传输请求和所述空闲连接池的线程数之间的差值;建立所述差值个属于所述空闲连接池的线程;检测到所述差值个属于所述空闲连接池的线程建立完成;确定所述差值个属于所述空闲连接池的线程和所述至少一个数据传输请求中剩余的数据传输请求之间的对应关系;将所述差值个属于所述空闲连接池的线程放入所述已使用连接池;若是,建立m个属于所述空闲连接池的线程以使得所述数据库连接池的线程数达到所述最大线程阈值;检测到所述m个属于所述空闲连接池的线程建立完成;确定所述m个属于所述空闲连接池的线程和所述至少一个数据传输请求中优先级序列位于所述第一数量+1位至所述第一数量+m位的数据传输请求之间的对应关系;将所述m个属于所述空闲连接池的线程放入所述已使用连接池。

举例来说,已使用连接池中原始的线程数量及第二数量为400,空闲连接池中原始的线程及第一数量为300且已经放入了已使用连接池中,若数据传输请求的数量为700,数据库连接池的最大线程阈值为1000,则400+700>1000,建立300个属于空闲连接池的线程使得数据库连接池中的线程的数量达到最大线程阈值,同时确定至少一个数据传输请求的优先级序列中位于第301位至第600位的数据传输请求与新建立的300个线程之间的对应关系,之后将新建立的300个线程放入已使用数据连接池。当已使用连接池中某个线程使用完成后将被释放,之后自动放入空闲连接池;银行服务器检测到空闲连接池中出现线程时,根据优先级序列确定601位、602位直至优先级序列中第1000位的数据传输请求与线程之间的对应关系确定完成。

可见,本示例中,银行服务器可根据数据传输请求的数量、数据库连接池的最大线程阈值和优先级序列安排至少一个数据传输请求中每个数据传输请求与线程之间的对应关系,及时的传输优先级更高的数据传输请求,提高了银行服务器的智能性。

在一个可能的示例中,所述数据库连接池包括空闲连接池和已使用连接池;所述状态信息包括所述空闲连接池中的线程数和已使用连接池的线程数;所述银行服务器根据所述至少一个数据传输请求的数量和所述状态信息执行数据连接操作,包括:判断所述至少一个数据传输请求的数量是否大于所述空闲连接池中的线程数;若否,则提取所述空闲连接池中所述至少一个数据传输请求的数量的可用连接线程;确定所述可用连接线程和所述至少一个数据传输请求之间的对应关系;将所述可用连接线程放入所述已使用连接池中。

可见,本示例中,银行服务器可直接使用数据库连接池中的空闲的线程,无需重新建立数据传输通道,节省了数据传输过程的时间,提高了数据传输的效率。

在一个可能的示例中,所述银行服务器获取当前接收到的至少一个数据传输请求的数量之前,所述方法还包括:获取当前的系统时间;确定所述系统时间所属的时间段;以所述时间段为查询标识,查询第三预设映射关系,获取所述时间段对应的最小线程数,所述第三预设映射关系包括时间段和最小线程数之间的对应关系;在所述数据库连接池和所述数据库之间建立所述最小线程数个线程。

可见,本示例中,银行服务器可根据当前的时间点对当前数据传输请求的数量进行预估,并根据预估情况建立最小线程数个线程,在保证有数据传输请求时的数据传输速率的同时,避免了建立过多的线程消耗数据库连接池的资源。

与上述图2所示的实施例一致的,请参阅图3,图3是本申请实施例提供的一种数据传输方法的流程示意图,应用于银行服务器。如图所示,本数据传输方法包括:

步骤301,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量。

步骤302,所述银行服务器获取所述第一数据库的数据库连接池的状态信息。

步骤303,所述银行服务器判断所述至少一个数据传输请求的数量是否大于所述第一数量。

步骤304,若是,则所述银行服务器获取所述至少一个数据传输请求中每个数据传输请求针对的目标业务类型。

步骤305,所述银行服务器以所述目标业务类型为查询标识,查询第一预设映射关系,获取所述目标业务类型对应的安全等级。

步骤306,所述银行服务器根据所述每个数据传输请求针对的所述目标业务类型和所述目标业务类型对应的所述安全等级确定所述每个数据传输请求关联的安全等级。

步骤307,所述银行服务器根据所述每个数据传输请求关联的安全等级确定所述至少一个数据传输请求的优先级序列。

步骤308,所述银行服务器检测到所述优先级序列中存在序列位置相同的至少两个数据传输请求。

步骤309,所述银行服务器获取所述至少两个数据传输请求中每个数据传输请求关联的账户信息。

步骤310,所述银行服务器以所述账户信息为查询标识,查询第二预设映射关系,获取所述账户信息对应的账户类别,所述第二预设映射关系包括账户信息和账户类别之间的对应关系,所述账户类别包括个人账户和企业账户,所述企业账户的优先级大于所述个人账户的优先级。

步骤311,所述银行服务器根据所述账户类别确定所述至少两个数据传输请求的优先级;根据所述至少两个数据传输请求的优先级更新所述优先级序列。

步骤312,所述银行服务器从所述优先级序列中筛选出前第一数量个数据传输请求,确定所述空闲连接池中的线程和所述前第一数量个数据传输请求之间的对应关系。

步骤313,所述银行服务器将所述空闲连接池中的线程放入所述已使用连接池。

可以看出,本申请实施例中,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;获取所述第一数据库的数据库连接池的状态信息;根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。可见,银行服务器可根据当前接收到的针对第一数据库的数据传输请求的数量和第一数据库的数据库连接池的状态动态调整数据传输策略以便于快速有序的从第一数据库录入和/或读取数据传输请求中需要的信息,达到了加速数据传输的效果,进而加快了银行服务器的数据处理效率。

此外,银行服务器可根据不同的业务类型确定不同的安全等级,进而优先处理安全等级较高的数据传输请求,在资源有限的条件下减小了重要信息泄漏的风险,提高了银行服务器中重要数据的安全性。。

与上述图2所示的实施例一致的,请参阅图4,图4是本申请实施例提供的一种数据传输方法的流程示意图,应用于银行服务器。如图所示,本数据传输方法包括:

步骤401,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量。

步骤402,所述银行服务器获取所述第一数据库的数据库连接池的状态信息。

步骤403,所述银行服务器判断所述至少一个数据传输请求的数量是否大于所述第一数量。

步骤404,若是,则所述银行服务器确定所述至少一个数据传输请求的优先级序列。

步骤405,所述银行服务器从所述优先级序列中筛选出前第一数量个数据传输请求,确定所述空闲连接池中的线程和所述前第一数量个数据传输请求之间的对应关系。

步骤406,所述银行服务器将所述空闲连接池中的线程放入所述已使用连接池。

步骤407,所述银行服务器判断所述至少一个数据传输请求的数量和所述第二数量之和是否大于所述数据库连接池的最大线程阈值。

步骤408,若否,所述银行服务器确定所述至少一个数据传输请求和所述空闲连接池的线程数之间的差值;建立所述差值个属于所述空闲连接池的线程;检测到所述差值个属于所述空闲连接池的线程建立完成;根据所述优先级序列确定所述差值个属于所述空闲连接池的线程和所述至少一个数据传输请求中剩余的数据传输请求之间的对应关系;将所述差值个属于所述空闲连接池的线程放入所述已使用连接池。

步骤409,若是,所述银行服务器建立m个属于所述空闲连接池的线程以使得所述数据库连接池的线程数达到所述最大线程阈值;检测到所述m个属于所述空闲连接池的线程建立完成;根据所述优先级序列确定所述m个属于所述空闲连接池的线程和所述至少一个数据传输请求中优先级序列位于所述第一数量+1位至所述第一数量+m位的数据传输请求之间的对应关系;将所述m个属于所述空闲连接池的线程放入所述已使用连接池。

可以看出,本申请实施例中,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;获取所述第一数据库的数据库连接池的状态信息;根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。可见,银行服务器可根据当前接收到的针对第一数据库的数据传输请求的数量和第一数据库的数据库连接池的状态动态调整数据传输策略以便于快速有序的从第一数据库录入和/或读取数据传输请求中需要的信息,达到了加速数据传输的效果,进而加快了银行服务器的数据处理效率。

此外,银行服务器可根据数据传输请求的数量、数据库连接池的最大线程阈值和优先级序列安排至少一个数据传输请求中每个数据传输请求与线程之间的对应关系,及时的传输优先级更高的数据传输请求,提高了银行服务器的智能性。

与上述图2、图3、图4所示的实施例一致的,请参阅图5,图5是本申请实施例提供的一种服务器500的结构示意图,如图所示,所述服务器500包括应用处理器510、存储器520、通信接口530以及一个或多个程序521,其中,所述一个或多个程序521被存储在上述存储器520中,并且被配置由上述应用处理器510执行,所述一个或多个程序521包括用于执行以下步骤的指令:

获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;

获取所述第一数据库的数据库连接池的状态信息;

根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。

可以看出,本申请实施例中,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;获取所述第一数据库的数据库连接池的状态信息;根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。可见,银行服务器可根据当前接收到的针对第一数据库的数据传输请求的数量和第一数据库的数据库连接池的状态动态调整数据传输策略以便于快速有序的从第一数据库录入和/或读取数据传输请求中需要的信息,达到了加速数据传输的效果,进而加快了银行服务器的数据处理效率。

在一个可能的示例中,所述数据库连接池包括空闲连接池和已使用连接池;所述状态信息包括所述空闲连接池中的线程的第一数量和已使用连接池的线程的第二数量;在所述根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作方面,所述程序中的指令具体用于执行以下操作:判断所述至少一个数据传输请求的数量是否大于所述第一数量;若是,则确定所述至少一个数据传输请求的优先级序列;从所述优先级序列中筛选出前第一数量个数据传输请求,确定所述空闲连接池中的线程和所述前第一数量个数据传输请求之间的对应关系;将所述空闲连接池中的线程放入所述已使用连接池。

在一个可能的示例中,在所述确定所述至少一个数据传输请求的优先级序列方面,所述程序中的指令具体用于执行以下操作:获取所述至少一个数据传输请求中每个数据传输请求针对的目标业务类型;以所述目标业务类型为查询标识,查询第一预设映射关系,获取所述目标业务类型对应的安全等级,所述第一预设映射关系包括业务类型和安全等级之间的对应关系;根据所述每个数据传输请求针对的所述目标业务类型和所述目标业务类型对应的所述安全等级确定所述每个数据传输请求关联的安全等级;根据所述每个数据传输请求关联的安全等级确定所述至少一个数据传输请求的优先级序列。

在一个可能的示例中,在所述根据所述每个数据传输请求关联的安全等级确定所述至少一个数据传输请求的优先级序列之后,所述程序中的指令还用于执行以下操作:检测到所述优先级序列中存在序列位置相同的至少两个数据传输请求;获取所述至少两个数据传输请求中每个数据传输请求关联的账户信息;以所述账户信息为查询标识,查询第二预设映射关系,获取所述账户信息对应的账户类别,所述第二预设映射关系包括账户信息和账户类别之间的对应关系,所述账户类别包括个人账户和企业账户,所述企业账户的优先级大于所述个人账户的优先级;根据所述账户类别确定所述至少两个数据传输请求的优先级;根据所述至少两个数据传输请求的优先级更新所述优先级序列。

在一个可能的示例中,在所述将所述空闲连接池中的线程放入所述已使用连接池之后,所述程序中的指令还用于执行以下操作:判断所述至少一个数据传输请求的数量和所述第二数量之和是否大于所述数据库连接池的最大线程阈值;若否,确定所述至少一个数据传输请求和所述空闲连接池的线程数之间的差值;建立所述差值个属于所述空闲连接池的线程;检测到所述差值个属于所述空闲连接池的线程建立完成;确定所述差值个属于所述空闲连接池的线程和所述至少一个数据传输请求中剩余的数据传输请求之间的对应关系;将所述差值个属于所述空闲连接池的线程放入所述已使用连接池;若是,建立m个属于所述空闲连接池的线程以使得所述数据库连接池的线程数达到所述最大线程阈值;检测到所述m个属于所述空闲连接池的线程建立完成;确定所述m个属于所述空闲连接池的线程和所述至少一个数据传输请求中优先级序列位于所述第一数量+1位至所述第一数量+m位的数据传输请求之间的对应关系;将所述m个属于所述空闲连接池的线程放入所述已使用连接池。

在一个可能的示例中,所述数据库连接池包括空闲连接池和已使用连接池;所述状态信息包括所述空闲连接池中的线程数和已使用连接池的线程数;在所述根据所述至少一个数据传输请求的数量和所述状态信息执行数据连接操作方面,所述程序中的指令还用于执行以下操作:判断所述至少一个数据传输请求的数量是否大于所述空闲连接池中的线程数;若否,则提取所述空闲连接池中所述至少一个数据传输请求的数量的可用连接线程;确定所述可用连接线程和所述至少一个数据传输请求之间的对应关系;将所述可用连接线程放入所述已使用连接池中。

在一个可能的示例中,在所述获取当前接收到的至少一个数据传输请求的数量之前,所述程序中的指令还用于执行以下操作:获取当前的系统时间;确定所述系统时间所属的时间段;以所述时间段为查询标识,查询第三预设映射关系,获取所述时间段对应的最小线程数,所述第三预设映射关系包括时间段和最小线程数之间的对应关系;在所述数据库连接池和所述数据库之间建立所述最小线程数个线程。

上述主要从方法侧执行过程的角度对本申请实施例的方案进行了介绍。可以理解的是,电子设备为了实现上述功能,其包含了执行各个功能相应的硬件结构和/或软件模块。本领域技术人员应该很容易意识到,结合本文中所提供的实施例描述的各示例的单元及算法步骤,本申请能够以硬件或硬件和计算机软件的结合形式来实现。某个功能究竟以硬件还是计算机软件驱动硬件的方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。

本申请实施例可以根据上述方法示例对电子设备进行功能单元的划分,例如,可以对应各个功能划分各个功能单元,也可以将两个或两个以上的功能集成在一个处理单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。需要说明的是,本申请实施例中对单元的划分是示意性的,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。

图6是本申请实施例中所涉及的数据传输装置600的功能单元组成框图。该数据传输装置600应用于银行服务器,包括处理单元601和通信单元602,其中,

所述处理单元601用于,获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;以及通过所述通信单元602获取所述第一数据库的数据库连接池的状态信息;以及根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。

其中,所述数据传输装置还可以包括存储单元603,用于存储电子设备的程序代码和数据。所述处理单元601可以是应用处理器,所述通信单元602可以是全局通信总线、收发器等,存储单元603可以是存储器。

可以看出,本申请实施例中,银行服务器获取当前接收到的针对第一数据库的至少一个数据传输请求的数量;获取所述第一数据库的数据库连接池的状态信息;根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作。可见,银行服务器可根据当前接收到的针对第一数据库的数据传输请求的数量和第一数据库的数据库连接池的状态动态调整数据传输策略以便于快速有序的从第一数据库录入和/或读取数据传输请求中需要的信息,达到了加速数据传输的效果,进而加快了银行服务器的数据处理效率。

在一个可能的示例中,所述数据库连接池包括空闲连接池和已使用连接池;所述状态信息包括所述空闲连接池中的线程的第一数量和已使用连接池的线程的第二数量;在所述根据所述至少一个数据传输请求的数量和所述状态信息执行针对所述至少一个数据传输请求中每个数据传输请求的数据传输操作方面,所述处理单元601用于:判断所述至少一个数据传输请求的数量是否大于所述第一数量;若是,则确定所述至少一个数据传输请求的优先级序列;从所述优先级序列中筛选出前第一数量个数据传输请求,确定所述空闲连接池中的线程和所述前第一数量个数据传输请求之间的对应关系;将所述空闲连接池中的线程放入所述已使用连接池。

在一个可能的示例中,在所述确定所述至少一个数据传输请求的优先级序列方面,所述处理单元601用于:获取所述至少一个数据传输请求中每个数据传输请求针对的目标业务类型;以所述目标业务类型为查询标识,查询第一预设映射关系,获取所述目标业务类型对应的安全等级,所述第一预设映射关系包括业务类型和安全等级之间的对应关系;根据所述每个数据传输请求针对的所述目标业务类型和所述目标业务类型对应的所述安全等级确定所述每个数据传输请求关联的安全等级;根据所述每个数据传输请求关联的安全等级确定所述至少一个数据传输请求的优先级序列。

在一个可能的示例中,在所述根据所述每个数据传输请求关联的安全等级确定所述至少一个数据传输请求的优先级序列之后,所所述处理单元601还用于:检测到所述优先级序列中存在序列位置相同的至少两个数据传输请求;获取所述至少两个数据传输请求中每个数据传输请求关联的账户信息;以所述账户信息为查询标识,查询第二预设映射关系,获取所述账户信息对应的账户类别,所述第二预设映射关系包括账户信息和账户类别之间的对应关系,所述账户类别包括个人账户和企业账户,所述企业账户的优先级大于所述个人账户的优先级;根据所述账户类别确定所述至少两个数据传输请求的优先级;根据所述至少两个数据传输请求的优先级更新所述优先级序列。

在一个可能的示例中,在所述将所述空闲连接池中的线程放入所述已使用连接池之后,所述处理单元601还用于:判断所述至少一个数据传输请求的数量和所述第二数量之和是否大于所述数据库连接池的最大线程阈值;若否,确定所述至少一个数据传输请求和所述空闲连接池的线程数之间的差值;建立所述差值个属于所述空闲连接池的线程;检测到所述差值个属于所述空闲连接池的线程建立完成;确定所述差值个属于所述空闲连接池的线程和所述至少一个数据传输请求中剩余的数据传输请求之间的对应关系;将所述差值个属于所述空闲连接池的线程放入所述已使用连接池;若是,建立m个属于所述空闲连接池的线程以使得所述数据库连接池的线程数达到所述最大线程阈值;检测到所述m个属于所述空闲连接池的线程建立完成;确定所述m个属于所述空闲连接池的线程和所述至少一个数据传输请求中优先级序列位于所述第一数量+1位至所述第一数量+m位的数据传输请求之间的对应关系;将所述m个属于所述空闲连接池的线程放入所述已使用连接池。

在一个可能的示例中,所述数据库连接池包括空闲连接池和已使用连接池;所述状态信息包括所述空闲连接池中的线程数和已使用连接池的线程数;在所述根据所述至少一个数据传输请求的数量和所述状态信息执行数据连接操作方面,所述处理单元601还用于:判断所述至少一个数据传输请求的数量是否大于所述空闲连接池中的线程数;若否,则提取所述空闲连接池中所述至少一个数据传输请求的数量的可用连接线程;确定所述可用连接线程和所述至少一个数据传输请求之间的对应关系;将所述可用连接线程放入所述已使用连接池中。

在一个可能的示例中,在所述获取当前接收到的至少一个数据传输请求的数量之前,所述处理单元601还用于:获取当前的系统时间;确定所述系统时间所属的时间段;以所述时间段为查询标识,查询第三预设映射关系,获取所述时间段对应的最小线程数,所述第三预设映射关系包括时间段和最小线程数之间的对应关系;在所述数据库连接池和所述数据库之间建立所述最小线程数个线程。

本申请实施例还提供一种计算机存储介质,其中,该计算机存储介质存储用于电子数据交换的计算机程序,该计算机程序使得计算机执行如上述方法实施例中记载的任一方法的部分或全部步骤,上述计算机包括电子设备。

本申请实施例还提供一种计算机程序产品,上述计算机程序产品包括存储了计算机程序的非瞬时性计算机可读存储介质,上述计算机程序可操作来使计算机执行如上述方法实施例中记载的任一方法的部分或全部步骤。该计算机程序产品可以为一个软件安装包,上述计算机包括电子设备。

需要说明的是,对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作和模块并不一定是本申请所必须的。

在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。

在本申请所提供的几个实施例中,应该理解到,所揭露的装置,可通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如上述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性或其它的形式。

上述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。

另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。

上述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储器中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储器中,包括若干指令用以使得一台计算机设备(可为个人计算机、服务器或者网络设备等)执行本申请各个实施例上述方法的全部或部分步骤。而前述的存储器包括:u盘、只读存储器(rom,read-onlymemory)、随机存取存储器(ram,randomaccessmemory)、移动硬盘、磁碟或者光盘等各种可以存储程序代码的介质。

本领域普通技术人员可以理解上述实施例的各种方法中的全部或部分步骤是可以通过程序来指令相关的硬件来完成,该程序可以存储于一计算机可读存储器中,存储器可以包括:闪存盘、只读存储器(英文:read-onlymemory,简称:rom)、随机存取器(英文:randomaccessmemory,简称:ram)、磁盘或光盘等。

以上对本申请实施例进行了详细介绍,本文中应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的一般技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1