CN115757455A - 数据处理方法及装置 - Google Patents
数据处理方法及装置 Download PDFInfo
- Publication number
- CN115757455A CN115757455A CN202211508874.9A CN202211508874A CN115757455A CN 115757455 A CN115757455 A CN 115757455A CN 202211508874 A CN202211508874 A CN 202211508874A CN 115757455 A CN115757455 A CN 115757455A
- Authority
- CN
- China
- Prior art keywords
- account
- updating
- data
- information
- resource data
- 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
Links
Images
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本公开是关于一种数据处理方法及装置,涉及数据处理技术领域,该方法包括:接收数据更新请求方发送的账户数据更新请求,所述账户数据更新请求中包括账户更新数据信息,所述账户更新数据信息包括账户信息和待更新账户资源数据;将所述账户更新数据信息存入数据库中,并向所述账户数据更新请求方反馈账户资源数据更新成功的响应信息;通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新。本公开的数据处理方法能够提升吞吐量,减少阻塞,缩短账户数据更新反馈的时间。
Description
技术领域
本公开涉及数据操作领域,尤其涉及一种数据处理方法及装置。
背景技术
账户系统负责记录并维护账户资源数据,在用户进行资金支付成功后,会在账户系统中增加账户资源数据。
目前账户系统收到账户数据更新请求后,在一个事务中去执行账户资源数据的更新,该账户资源数据的更新主要包括三步:更改账户资源数据、查询更新后的账户资源数据以及插入账户资源数据信息。
在执行上述方法时,至少存在如下问题:一个账户资源数据更新请求需执行3个SQL才能释放,锁行时间长,导致账户资源数据更新反馈时间长,账户资源数据更新吞吐量低;当一家的账户资源数据更新请求较多时会影响其它家账户资源数据更新请求操作,导致账户资源数据更新阻塞。
发明内容
本公开提供一种数据处理方法及装置,能够提升吞吐量,减少阻塞,缩短账户数据更新反馈的时间。本公开的技术方案如下:
根据本公开实施例的第一方面,提供一种数据处理方法,包括:
接收数据更新请求方发送的账户数据更新请求,所述账户数据更新请求中包括账户更新数据信息,所述账户更新数据信息包括账户信息和待更新账户资源数据;
将所述账户更新数据信息存入数据库中,并向所述账户数据更新请求方反馈账户资源数据更新成功的响应信息;
通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新。
在本公开的一些实施例中,所述通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新,包括:
从所述数据库中读取所述账户更新数据信息;
根据所述账户更新数据信息中的账户信息确定账户类型;
根据所述账户类型将所述账户更新数据信息分流到对应的队列中;
针对任一队列,基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新。
在本公开的一些实施例中,所述账户类型包括:预设时间段内账户资源数据更新频率大于或等于预设频率阈值的第一类型账户,所述预设时间段内账户资源数据更新频率小于所述预设频率阈值的第二类型账户。
在本公开的一些实施例中,当所述账户类型为第二类型账户时,所述基于队列对应的账户资源数据更新规则进行对应账户资源数据的更新,包括:
从所述第二类型账户对应的队列中逐一拉取账户更新数据信息;
针对各所述账户更新数据信息,并行根据账户更新数据信息中的待更新账户资源数据进行对应账户资源数据的更新。
在本公开的一些实施例中,当所述账户类型为第一类型账户时,所述基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新,包括:
从所述第一类型账户对应的队列中拉取预定数量的账户更新数据信息;
对所述预设数量的账户更新数据信息进行分组处理,得到至少一个数据组,针对任一所述数据组,所述数据组中的各所述账户更新数据信息包括同一所述账户信息;
针对任一所述数据组,对所述数据组中各所述账户更新数据信息中的待更新账户资源数据进行汇总,得到汇总待更新账户资源数据,并根据所述汇总待更新账户资源数据对所述账户信息对应的账户进行账户资源数据的更新。
在本公开的一些实施例中,在基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新之后,所述方法还包括:
针对任一所述账户更新数据信息,在基于所述账户更新数据信息的账户资源数据更新成功后,在所述数据库中为所述账户更新数据信息设置第一标记,所述第一标记用于表征账户资源数据更新已完成;或者,
在基于所述账户更新数据信息的账户资源数据更新失败后,在所述数据库中为所述账户更新数据信息设置第二标记,所述第二标记用于表征账户资源数据更新未完成。
在本公开的一些实施例中,所述方法还包括:
从所述数据库中获取待处理信息,所述待处理信息包括具有所述第二标记的所述账户更新数据信息;
针对任一所述待处理信息,根据账户类型将所述待处理信息分流到对应的队列中进行对应账户资源数据的更新,直至完成所述待处理信息对应的账户资源数据的更新,将所述待处理信息的所述第二标记更新为所述第一标记。
根据本公开实施例的第二方面,提供一种数据处理装置,包括:
接收单元,被配置为接收数据更新请求方发送的账户数据更新请求,所述账户数据更新请求中包括账户更新数据信息,所述账户更新数据信息包括账户信息和待更新账户资源数据;
操作单元,被配置为将所述账户更新数据信息存入数据库中,并向所述账户数据更新请求方反馈账户数据更新成功的响应信息;
数据更新单元,被配置为通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新。
根据本公开实施例的第三方面,提供一种电子设备,包括:
处理器;
用于存储所述处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述指令,以实现如第一方面所述的数据处理方法。
根据本公开实施例的第四方面,供一种存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如上第一方面所述的数据处理方法。
根据本公开实施例的第五方面,提供一种计算机程序产品,包括计算机程序,所述计算机程序被处理器执行时实现如上第一方面所述的数据处理方法。
本公开的实施例提供的技术方案至少带来以下有益效果:本公开的实施例,在接收到账户数据更新请求之后,将账户更新数据信息存入数据库,并向数据更新请求方反馈账户资源数据更新成功的响应信息,该种账户数据更新反馈方式,只要将账户更新数据信息存入数据库中,即可进行账户资源数据更新成功的反馈,相比现有技术中的实现方式,能够较大程度缩短反馈账户资源数据更新成功的时间。在将该账户更新数据信息存入数据库之后,继续接收新的账户数据更新请求,继续处理。而存入数据库中的账户更新数据信息将被从数据库中读取出来,基于该账户更新数据信息完成对应账户资源数据的更新,由于进行账户资源数据更新的账户更新数据信息是接收并存储在数据库中的,能够保证账户资源数据更新数据源以及账户资源数据更新的准确性,并且一次账户数据更新请求的完成不再受账户资源数据更新操作锁行的限制,账户数据更新反馈和账户资源数据更新操作异步进行,与现有技术相比,避免了由于锁行操作导致的账户资源数据更新阻塞,提升了吞吐量。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理,并不构成对本公开的不当限定。
图1是根据一示例性实施例示出的一种数据处理方法的流程图;
图2是根据一示例性实施例示出的一种数据处理方法的流程图;
图3是根据一示例性实施例示出的一种数据处理方法的流程图;
图4是根据一示例性实施例示出的一种数据处理装置的框图;
图5是根据一示例性实施例示出的一种数据处理装置的框图;
图6是根据一示例性实施例示出的一种数据处理装置的框图;
图7是根据一示例性实施例示出的一种数据处理装置的框图;
图8是根据一示例性实施例示出的一种电子设备的框图;
图9是根据一示例性实施例示出的一种电子设备的框图。
具体实施方式
为了使本领域普通人员更好地理解本公开的技术方案,下面将结合附图,对本公开实施例中的技术方案进行清楚、完整地描述。
需要说明的是,本公开的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本公开的实施例能够以除了在这里图示或描述的那些以外的顺序实施。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
账户系统负责记录并维护账户资源数据,在用户进行资金支付成功后,会在账户系统中增加账户资源数据。目前账户系统收到账户数据更新请求后,在一个事务中去执行账户资源数据的更新,该账户资源数据的更新主要包括三步:更改账户资源数据、查询更新后的账户资源数据以及插入账户资源数据信息。在执行上述方法时,至少存在如下问题:一个账户资源数据更新请求需执行3个SQL才能释放,锁行时间长,导致账户资源数据更新反馈时间长,账户资源数据更新吞吐量低;当一家的账户资源数据更新请求较多时会影响其它家账户资源数据更新请求操作,导致账户资源数据更新阻塞。
为进行上述技术问题的解决,本发明提供一种数据处理方法及装置,具体的,如图1所示,图1是根据一示例性实施例示出的一种数据处理方法的流程图,包括以下步骤。
步骤101、接收数据更新请求方发送的账户数据更新请求,所述账户数据更新请求中包括账户更新数据信息,所述账户更新数据信息包括账户信息和待更新账户资源数据。
该处需要说明的是,账户系统负责记录并维护账户资源数据,在用户进行资金支付成功后,会在账户系统中增加账户资源数据,本公开的实施例,在接收到账户数据更新请求后,会将该账户数据更新请求中携带的账户更新数据信息存入数据库,以便后续进行对应账户资源数据的更新操作。
本公开的实施例中的账户更新数据信息至少包括账户信息和待更新账户资源数据。
本公开实施例中,该账户信息为账户的标识信息,用于进行账户的区分。该待更新账户资源数据需要写入对应的账户中,进行该账户资源数据的更新。
步骤102、将所述账户更新数据信息存入数据库中,并向所述账户数据更新请求方反馈账户资源数据更新成功的响应信息。
本公开实施例中的数据库可以是任一种数据库,比如mysql数据库,具体对此不进行限制。在将账户更新数据信息插入数据库时,使用任一种数据库操作对应的数据插入方法,本公开的实施例对此不进行限制。
在将账户更新数据信息插入数据库后,默认为账户资源数据更新成功,基于该数据更新请求反馈账户资源数据更新成功的响应信息,以便用户能够及时得到账户资源数据更新的反馈。
步骤103、通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新。
本公开的实施例中,存入数据库中的账户更新数据信息为数据更新请求方携带在账户数据更新请求中的原始数据,是完成账户资源数据更新的数据源。
本公开的实施例中,在接收到账户数据更新请求之后,将账户更新数据信息存入数据库,并向数据更新请求方反馈账户资源数据更新成功的响应信息,该种账户数据更新反馈方式,只要将账户更新数据信息存入数据库中,即可进行账户资源数据更新成功的反馈,相比现有技术中的实现方式,能够较大程度缩短反馈账户资源数据更新成功的时间。在将该账户更新数据信息存入数据库之后,继续接收新的账户数据更新请求,继续处理。而存入数据库中的账户更新数据信息将被从数据库中读取出来,基于该账户更新数据信息完成对应账户资源数据的更新,由于进行账户资源数据更新的账户更新数据信息是接收并存储在数据库中的,能够保证账户资源数据更新数据源以及账户资源数据更新的准确性,并且一次账户数据更新请求的完成不再受账户资源数据更新操作锁行的限制,账户数据更新反馈和账户资源数据更新操作异步进行,与现有技术相比,避免了由于锁行操作导致的账户资源数据更新阻塞,提升了吞吐量。
为了实现对应账户的账户资源数据的更新,本公开的实施例通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新,可以通过但不局限于以下的方法实现,如图2所示,该方法包括:
步骤1031、从所述数据库中读取所述账户更新数据信息。
数据库进行账户更新数据信息的记录时,每条记录均有一个数据库记录编号信息,该数据库记录编号信息用于表征账户更新数据信息的写入顺序。在从数据中进行账户更新数据信息的读取时,可以按照写入数据库的顺序进行账户更新数据信息的读取,也可以采用其他的方式进行,具体的,本公开的实施例对此不进行限制。
步骤1032、根据所述账户更新数据信息中的账户信息确定账户类型。
本公开的实施例,该处需要说明的是,该账户类型是已知的,在发送账户数据更新请求时便已经标识。该账户类型包括:预设时间段内账户资源数据更新频率大于或等于预设频率阈值的第一类型账户,所述预设时间段内账户资源数据更新频率小于所述预设频率阈值的第二类型账户。其中,预设时间段为预先设定的时间范围,具体取值可以由本领域技术人员按照更新需求进行设定,例如:预设时间段可以为10分钟内。
示例性的,针对任一账户信息,可以统计在预设时间段内写入数据库中包括该账户信息的账户更新数据信息的数量,将该数量作为该账户信息对应的账户资源数据更新频率,并在该账户资源数据更新频率大于或等于预设频率阈值时,确定该账户信息对应第一类型账户,或者在账户资源数据更新频率小于预设频率阈值时,确定该账户信息对应第二类型账户。
步骤1033、根据所述账户类型将所述账户更新数据信息分流到对应的队列中。
本公开的实施例中,根据不同账户类型建立对应的队列,在进行账户资源数据更新时,根据所述账户类型将所述账户更新数据信息分流到对应的队列中。比如,若该账户类型为第一类型账户,则将账户更新数据信息分流到第一类型账户队列中,若该账户类型为第二类型账户,则将账户更新数据信息分流到第二类账户队列中。
步骤1034、针对任一队列,基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新。
不同的账户类型对应不同的账户资源数据更新规则。针对一种类型的队列,使用该队列对应的账户资源数据更新规则进行对应账户资源数据的更新。
本公开的实施例,在对账户资源数据进行更新时,进行账户类型的划分,不同的账户类型建立不同的账户更新数据信息处理的队列,针对不同的队列设置不同的账户资源数据处理规则,针对不同类型的账户有针对性的处理规则,并且,不同类型的账户基于不同的队列并行处理,避免账户资源数据更新的阻塞,提高了系统吞吐量。
本公开的一些实施例中,当所述账户类型为第二类型账户时,该第二类型账户可以为非热点账户,该非热点账户其流水比较平稳,更新频率一般,账户资源数据处理占用时间正常,本公开的实施例使用线程池的方式进账户资源数据的处理。具体的基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新时,可以采用但不局限于以下的方式,该方式包括:
从所述第二类型账户对应的队列中逐一拉取账户更新数据信息。
针对各所述账户更新数据信息,并行根据账户更新数据信息中的待更新账户资源数据进行对应账户资源数据的更新。
本公开的实施例,在从第二类账户对应的队列中拉取账户更新数据信息时,将第一条账户更新数据信息从该第二类账户对应队列拉取,将该第一条账户更新数据信息从队列中拉取之后,会顺序拉取第二类账户对应的队列中的第二条账户更新数据信息,将该拉取的账户更新数据信息放进不同的线程进行,并行根据账户更新数据信息中的待更新账户资源数据进行对应账户资源数据的更新。
该种账户资源数据的更新,由于其数据量不大,通过并行线程的方式进行,能够及时的完成待对应账户资源数据的更新,保证了账户资源数据更新的及时性。
当所述账户类型为第一类型账户时,该第一类型账户可以为热点账户,当为热点账户时,其账户资源数据更新的频率相对较高,账户数据更新占用时间较长。可以通过批量数据更新处理的方式进行,具体的基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新,可以采用但不局限于以下的方法实现,包括:
从所述第一类型账户对应的队列中拉取预定数量的账户更新数据信息;
对所述预设数量的账户更新数据信息进行分组处理,得到至少一个数据组,针对任一所述数据组,所述数据组中的各所述账户更新数据信息包括同一所述账户信息;
针对任一所述数据组,对所述数据组中各所述账户更新数据信息中的待更新账户资源数据进行汇总,得到汇总待更新账户资源数据,并根据所述汇总待更新账户资源数据对所述账户信息对应的账户进行账户资源数据的更新。
本公开的实施例,由于第一类型账户其账户资源数据更新的频率相对较高,所述第一类型账户对应的队列中多个账户更新数据信息可能是同一个账户的账户更新数据信息,故在所述第一类型账户对应的队列中拉取账户更新数据信息时,会批量一次拉取多个账户更新数据信息,并对拉取的多个账户更新数据信息,按照账户进行分组,得到至少一个数据组,该数据组可能为一个,也可能为两个,也可以为多个,要根据具体拉取的多个账户更新数据信息中包括的账户信息确定,本公开的实施例对此不进行限制。
如上所述,一个数据组中的账户更新数据信息可能有多个,也可能有一个,具体的本公开的实施例对此也不进行限制。当为一个时,就将该一个账户更新数据信息对所述账户信息对应的账户进行账户资源数据的更新;当为多个时,将一个数据组中的多个账户更新数据信息中的待更新账户资源数据进行汇总,得到汇总待更新账户资源数据,并根据所述汇总待更新账户资源数据对所述账户信息对应的账户进行账户资源数据的更新。比如,当为多个时,比如为200,可以将该200个账户更新数据信息中的待更新账户资源数据进行汇总,得到汇总待更新账户资源数据,并根据所述汇总待更新账户资源数据对所述账户信息对应的账户进行账户资源数据的更新。
本公开的实施例,通过对同一个账户的多个账户更新数据信息进行批量汇总的方式对该账户的账户资源数据进行更新,避免了每条账户更新数据信息均进行一次账户资源数据更新操作,避免了由于进行账户资源数据更新操作的锁行操作,导致的账户资源数据更新阻塞,提升了吞吐量。
在本公开的一些实施例中,为了保障存储在数据库中的账户更新数据信息均进行对应账户数据资源信息的成功更新,在基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新之后,本公开的实施例还提供如下的方法,包括:
针对任一所述账户更新数据信息,在基于所述账户更新数据信息的账户资源数据更新成功后,在所述数据库中为所述账户更新数据信息设置第一标记,所述第一标记用于表征账户资源数据更新已完成;或者,
在基于所述账户更新数据信息的账户资源数据更新失败后,在所述数据库中为所述账户更新数据信息设置第二标记,所述第二标记用于表征账户资源数据更新未完成。
本公开的实施例中,在基于所述账户更新数据信息的账户资源数据更新成功后,在所述数据库中为所述账户更新数据信息设置第一标记时,该第一标记可以为但不局限于文字信息,比如为已完成;或者可以为与非信息,比如为是;或者可以为标志位信息,比如0;具体的本公开的实施例对此不进行限制。
在基于所述账户更新数据信息的账户资源数据更新失败后,在所述数据库中为所述账户更新数据信息设置第二标记时,该第一标记可以为但不局限于文字信息,比如为未完成;或者可以为与非信息,比如为否;或者可以为标志位信息,比如1;具体的本公开的实施例对此不进行限制。
本公开的实施例,对根据账户更新数据信息进行账户资源数据更新是否成功进行了标记,以便对没有更新成功的账户更新数据信息对应的账户资源数据重新进行更新,保证了已反馈账户资源数据更新成功的一致性。
本公开的实施例,在所述数据库中为所述账户更新数据信息设置用于表征账户资源数据更新是否已完成时,可以采用标记位的方式,也可以采用其他的方式,具体的本公开的实施例对此不进行限制。
进一步的,为了保证账户资源数据的更新成功,该方法还包括:
步骤a、从所述数据库中获取待处理信息,所述待处理信息包括具有所述第二标记的所述账户更新数据信息。
步骤b、针对任一所述待处理信息,根据账户类型将所述待处理信息分流到对应的队列中进行对应账户资源数据的更新,直至完成所述待处理信息对应的账户资源数据的更新,将所述待处理信息的所述第二标记更新为所述第一标记。
本公开的实施例该处需要说明的是,如上所述的具有所述第二标记的所述账户更新数据信息为账户资源数据更新不成功,需要重新进行账户资源数据更新的账户更新数据信息,在重新进行账户资源数据的更新时,采用上述的方法进行,具体的本实施例此处将不再赘述。当账户资源数据更新成功后,在数据库中将该账户更新数据信息的表征账户资源数据更新是是否完成的标记位,从第二标记变更为第二标记。保障了账户资源数据的更新与向数据更新请求方反馈账户资源数据更新成功的一致性。
本公开的实施例,在接收到账户数据更新请求之后,将账户更新数据信息存入数据库,并向数据更新请求方反馈账户资源数据更新成功的响应信息,该种账户数据更新反馈方式,只要将账户更新数据信息存入数据库中,即可进行账户资源数据更新成功的反馈,相比现有技术中的实现方式,能够较大程度缩短反馈账户资源数据更新成功的时间。在将该账户更新数据信息存入数据库之后,继续接收新的账户数据更新请求,继续处理。而存入数据库中的账户更新数据信息将被从数据库中读取出来,基于该账户更新数据信息完成对应账户资源数据的更新,由于进行账户资源数据更新的账户更新数据信息是接收并存储在数据库中的,能够保证账户资源数据更新数据源以及账户资源数据更新的准确性,并且一次账户数据更新请求的完成不再受账户资源数据更新操作锁行的限制,账户数据更新反馈和账户资源数据更新操作异步进行,与现有技术相比,避免了由于锁行操作导致的账户资源数据更新阻塞,提升了吞吐量。
并且,本公开的实施例为了保障账户资源数据成功更新,设置了对应的账户资源数据更新是否成功的标识信息以及重复进行账户资源数据更新的机制,保障了将账户更新数据信息存入数据库之后就反馈账户资源数据更新成功的反馈信息的一致性。
基于上述的描述,本公开的实施例以账户系统为基础,该账户数据更新请求为记账请求为例进行数据处理方法的具体描述,如图3所示,该方法包括如下执行步骤:
1、账户更新数据信息插入:
账户系统接收到数据更新请求方发送的记账请求之后,会将记账请求中账户更新数据信息插入数据库,然后基于该记账请求对上游数据更新请求方同步返回账户资源数据更新成功的响应信息,后面账户资源数据的更新就提交给MQ进行异步处理。
2、队列分流:
在投递账户更新数据信息消息给MQ时,进行账户更新数据信息的分流处理。账户更新数据信息的分流处理,基于账户类型进行,该账户类型包括(第一类型账户)热点账户和(第二类型账户)非热点账户,即普通账户,如果是热点账户则投递到热点账户队列,否则投递到普通账户队列。
3、流水消息处理:
在将账户更新数据信息分流到普通账户队列,普通账户队列接收到账户更新数据信息消息之后,并行根据账户更新数据信息中的待更新账户资源数据进行对应账户资源数据的更新,具体的可以采用但不局限于按账户信息使用不同的线程池并行进行账户资源数据的更新。
在将账户更新数据信息分流到热点账户队列,热点账户队列接收到账户更新数据信息消息之后,在内存中按账户维度进行账户更新数据信息的汇总。从该热点账户队列获取一次拉取预定数量的账户更新数据信息,将同一个账户下的账户更新数据信息聚类在一个分组中,进行账户更新数据信息的批量处理。每组中账户更新数据信息中的账户更新数据进行汇总得到汇总待更新账户资源数据,基于该汇总待更新账户资源数据进行账户资源数据的更新。本公开的实施例中,该预定数量为一个经验值,其可以根据实际情况动态调整,比如可以为200。
本公开的实施例中,一次将200个账户更新数据信息进行处理,达到批量更新的目的。在进行批量更新时,相当于把一个200账户更新数据信息账户资源数据更新的大事务拆解成两个事务,第一个事务是将200个账户更新数据信息按照账户生成对应的中间汇总待更新账户资源数据;第二个事务使用该汇总待更新账户资源数据去更新账户资源数据,实现对应账户资源数据的更新。
本公开的实施例,在接收到账户数据更新请求之后,将账户更新数据信息存入数据库,并向数据更新请求方反馈账户资源数据更新成功的响应信息,该种账户数据更新反馈方式,只要将账户更新数据信息存入数据库中,即可进行账户资源数据更新成功的反馈,相比现有技术中的实现方式,能够较大程度缩短反馈账户资源数据更新成功的时间。在将该账户更新数据信息存入数据库之后,继续接收新的账户数据更新请求,继续处理。而存入数据库中的账户更新数据信息将被从数据库中读取出来,基于该账户更新数据信息完成对应账户资源数据的更新,由于进行账户资源数据更新的账户更新数据信息是接收并存储在数据库中的,能够保证账户资源数据更新数据源以及账户资源数据更新的准确性,并且一次账户数据更新请求的完成不再受账户资源数据更新操作锁行的限制,账户数据更新反馈和账户资源数据更新操作异步进行,与现有技术相比,避免了由于锁行操作导致的账户资源数据更新阻塞,提升了吞吐量。
并且,当记账请求的账户为热点账户时,针对接收到的账户更新数据信息进行批量汇总处理,将批量账户更新数据信息汇总成一个汇总待更新账户资源数据,进行账户资源数据更新的时候,去更新汇总待更新账户资源数据即可,较大的提升账户系统账户资源数据的吞吐量。经过试验,与现有技术中的50次/秒提升到5000次/秒。
基于上述图1-图3提供的数据处理方法的具体描述,如图4所示,图4是根据一示例性实施例示出的一种数据处理装置框图。参照图1,该装置包括:接收单元401,操作单元402、数据更新单元403。
接收单元401,被配置为接收数据更新请求方发送的账户数据更新请求,所述账户数据更新请求中包括账户更新数据信息,所述账户更新数据信息包括账户信息和待更新账户资源数据;
操作单元402,被配置为将所述账户更新数据信息存入数据库中,并向所述账户数据更新请求方反馈账户数据更新成功的响应信息;
数据更新单元403,被配置为通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新。
在本公开的一些实施例中,如图5所示,所述数据更新单元403包括:
读取模块4031,被配置为从所述数据库中读取所述账户更新数据信息;
确定模块4032,被配置为根据所述账户更新数据信息中的账户信息确定账户类型;
分流模块4033,被配置为根据所述账户类型将所述账户更新数据信息分流到对应的队列中;
更新模块4034,被配置为针对任一队列,基于所述的队列按照对应的账户资源数据更新规则进行对应账户资源数据的更新。
在本公开的一些实施例中,所述账户类型包括:预设时间段内账户资源数据更新频率大于或等于预设频率阈值的第一类型账户,所述预设时间段内账户资源数据更新频率小于所述预设频率阈值的第二类型账户。
在本公开的一些实施例中,当所述账户类型为第二类型账户时,所述更新模块4034包括:
从所述第二类型账户对应的队列中逐一拉取账户更新数据信息;
针对各所述账户更新数据信息,并行根据账户更新数据信息中的待更新账户资源数据进行对应账户资源数据的更新。
在本公开的一些实施例中,当所述账户类型为第一类型账户时,所述更新模块4034包括:
从所述第一类型账户对应的队列中拉取预定数量的账户更新数据信息;
对所述预设数量的账户更新数据信息进行分组处理,得到至少一个数据组,针对任一所述数据组,所述数据组中的各所述账户更新数据信息包括同一所述账户信息;
针对任一所述数据组,对所述数据组中各所述账户更新数据信息中的待更新账户资源数据进行汇总,得到汇总待更新账户资源数据,并根据所述汇总待更新账户资源数据对所述账户信息对应的账户进行账户资源数据的更新。
在本公开的一些实施例中,如图6所示,所述数据处理装置还包括标记单元404。
标记单404,被配置为针对任一所述账户更新数据信息,在基于所述账户更新数据信息的账户资源数据更新成功后,在所述数据库中为所述账户更新数据信息设置第一标记,所述第一标记用于表征账户资源数据更新已完成;
所述标记单404,还被配置在基于所述账户更新数据信息的账户资源数据更新失败后,在所述数据库中为所述账户更新数据信息设置第二标记,所述第二标记用于表征账户资源数据更新未完成。
在本公开的一些实施例中,如图7所示,所述数据更新装置还包括:获取单元405。
获取单元405,被配置为从所述数据库中获取待处理信息,所述待处理信息包括具有所述第二标记的所述账户更新数据信息;
所述数据更新单元403,被配置为针对任一所述待处理信息,根据账户类型将所述待处理信息分流到对应的队列中进行对应账户资源数据的更新,直至完成所述待处理信息对应的账户资源数据的更新,将所述待处理信息的所述第二标记更新为所述第一标记。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
本公开的实施例,本公开的实施例,在接收到账户数据更新请求之后,将账户更新数据信息存入数据库,并向数据更新请求方反馈账户资源数据更新成功的响应信息,该种账户数据更新反馈方式,只要将账户更新数据信息存入数据库中,即可进行账户资源数据更新成功的反馈,相比现有技术中的实现方式,能够较大程度缩短反馈账户资源数据更新成功的时间。在将该账户更新数据信息存入数据库之后,继续接收新的账户数据更新请求,继续处理。而存入数据库中的账户更新数据信息将被从数据库中读取出来,基于该账户更新数据信息完成对应账户资源数据的更新,由于进行账户资源数据更新的账户更新数据信息是接收并存储在数据库中的,能够保证账户资源数据更新数据源以及账户资源数据更新的准确性,并且一次账户数据更新请求的完成不再受账户资源数据更新操作锁行的限制,账户数据更新反馈和账户资源数据更新操作异步进行,与现有技术相比,避免了由于锁行操作导致的账户资源数据更新阻塞,提升了吞吐量。
并且,本公开的实施例为了保障账户资源数据成功更新,设置了对应的账户资源数据更新是否成功的标识信息以及重复进行账户资源数据更新的机制,保障了将账户更新数据信息存入数据库之后就反馈账户资源数据更新成功的反馈信息的一致性。
图8是本公开示出的一种电子设备800的框图。例如,电子设备800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图7,电子设备800可以包括以下一个或多个组件:处理组件802,存储器804,电力组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制电子设备800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成任一实施例所述的信息平台选择方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在电子设备800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件806为电子设备800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为电子设备800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述电子设备800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当电子设备800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为电子设备800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为电子设备800的显示器和小键盘,传感器组件814还可以检测电子设备800或电子设备800一个组件的位置改变,用户与电子设备800接触的存在或不存在,电子设备800方位或加速/减速和电子设备800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于电子设备800和其他设备之间有线或无线方式的通信。电子设备800可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行任一实施例所述的信息平台选择方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由电子设备800的处理器820执行以完成任一实施例所述的信息平台选择方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
在示例性实施例中,还提供了一种计算机程序产品,该计算机程序产品包括可读性程序代码,该可读性程序代码可由装置800的处理器820执行以完成任一实施例所述的信息平台选择方法。可选地,该程序代码可以存储在装置800的存储介质中,该存储介质可以是非临时性计算机可读存储介质,例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
图9是本公开示出的一种电子设备1900的框图。例如,电子设备1900可以被提供为一服务器。
参照图9,电子设备1900包括处理组件1922,其进一步包括一个或多个处理器,以及由存储器1932所代表的存储器资源,用于存储可由处理组件1922的执行的指令,例如应用程序。存储器1932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1922被配置为执行指令,以执行任一实施例所述的信息平台选择方法。
电子设备1900还可以包括一个电源组件1926被配置为执行电子设备1900的电源管理,一个有线或无线网络接口1950被配置为将电子设备1900连接到网络,和一个输入输出(I/O)接口1958。电子设备1900可以操作基于存储在存储器1932的操作系统,例如WindowsS erverTM,MacOSXTM,UnixTM,LinuxTM,FreeBSDTM或类似。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。
Claims (10)
1.一种数据处理方法,其特征在于,包括:
接收数据更新请求方发送的账户数据更新请求,所述账户数据更新请求中包括账户更新数据信息,所述账户更新数据信息包括账户信息和待更新账户资源数据;
将所述账户更新数据信息存入数据库中,并向所述账户数据更新请求方反馈账户资源数据更新成功的响应信息;
通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新。
2.根据权利要求1所述的方法,其特征在于,所述通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新,包括:
从所述数据库中读取所述账户更新数据信息;
根据所述账户更新数据信息中的账户信息确定账户类型;
根据所述账户类型将所述账户更新数据信息分流到对应的队列中;
针对任一队列,基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新。
3.根据权利要求2所述的方法,其特征在于,所述账户类型包括:预设时间段内账户资源数据更新频率大于或等于预设频率阈值的第一类型账户,所述预设时间段内账户资源数据更新频率小于所述预设频率阈值的第二类型账户。
4.根据权利要求3所述的方法,其特征在于,当所述账户类型为第二类型账户时,所述基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新,包括:
从所述第二类型账户对应的队列中逐一拉取账户更新数据信息;
针对各所述账户更新数据信息,并行根据账户更新数据信息中的待更新账户资源数据进行对应账户资源数据的更新。
5.根据权利要求3所述的方法,其特征在于,当所述账户类型为第一类型账户时,所述基于所述队列对应的账户资源数据更新规则进行对应账户资源数据的更新,包括:
从所述第一类型账户对应的队列中拉取预定数量的账户更新数据信息;
对所述预设数量的账户更新数据信息进行分组处理,得到至少一个数据组,针对任一所述数据组,所述数据组中的各所述账户更新数据信息包括同一所述账户信息;
针对任一所述数据组,对所述数据组中各所述账户更新数据信息中的待更新账户资源数据进行汇总,得到汇总待更新账户资源数据,并根据所述汇总待更新账户资源数据对所述账户信息对应的账户进行账户资源数据的更新。
6.根据权利要求2至4中任一项所述的方法,其特征在于,所述方法还包括:
针对任一所述账户更新数据信息,在基于所述账户更新数据信息的账户资源数据更新成功后,在所述数据库中为所述账户更新数据信息设置第一标记,所述第一标记用于表征账户资源数据更新已完成;或者,
在基于所述账户更新数据信息的账户资源数据更新失败后,在所述数据库中为所述账户更新数据信息设置第二标记,所述第二标记用于表征账户资源数据更新未完成。
7.根据权利要求6所述的方法,其特征在于,所述方法还包括:
从所述数据库中获取待处理信息,所述待处理信息包括具有所述第二标记的所述账户更新数据信息;
针对任一所述待处理信息,根据账户类型将所述待处理信息分流到对应的队列中进行对应账户资源数据的更新,直至完成所述待处理信息对应的账户资源数据的更新,将所述待处理信息的所述第二标记更新为所述第一标记。
8.一种数据处理装置,其特征在于,包括:
接收单元,被配置为接收数据更新请求方发送的账户数据更新请求,所述账户数据更新请求中包括账户更新数据信息,所述账户更新数据信息包括账户信息和待更新账户资源数据;
操作单元,被配置为将所述账户更新数据信息存入数据库中,并向所述账户数据更新请求方反馈账户资源数据更新成功的响应信息;
数据更新单元,被配置为通过从所述数据库中读取所述账户更新数据信息完成对应账户资源数据的更新。
9.一种电子设备,其特征在于,包括:
处理器;
用于存储所述处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述指令,以实现如权利要求1至7中任一项所述的数据处理方法。
10.一种存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如权利要求1至7中任一项所述的数据处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211508874.9A CN115757455A (zh) | 2022-11-29 | 2022-11-29 | 数据处理方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211508874.9A CN115757455A (zh) | 2022-11-29 | 2022-11-29 | 数据处理方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115757455A true CN115757455A (zh) | 2023-03-07 |
Family
ID=85340761
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211508874.9A Pending CN115757455A (zh) | 2022-11-29 | 2022-11-29 | 数据处理方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115757455A (zh) |
-
2022
- 2022-11-29 CN CN202211508874.9A patent/CN115757455A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105898032B (zh) | 提示音的调整方法和装置 | |
US20150339016A1 (en) | Tab creation method, device, and terminal | |
EP3136697B1 (en) | Contact record processing method and apparatus | |
CN108804244B (zh) | 数据发送方法、装置及存储介质 | |
CN111880681A (zh) | 触摸屏采样速率调节方法、装置及计算机存储介质 | |
CN109245992B (zh) | 请求处理方法、装置、电子设备及存储介质 | |
CN110968492A (zh) | 信息处理方法及装置、存储介质 | |
CN107704489B (zh) | 读写超时的处理方法、装置及计算机可读存储介质 | |
CN115757455A (zh) | 数据处理方法及装置 | |
CN112035246B (zh) | 虚拟资源的获取方法、装置、系统、电子设备及存储介质 | |
CN111681118B (zh) | 一种数据处理方法及装置 | |
CN114239531A (zh) | 模板推荐方法、装置、电子设备及存储介质 | |
CN108737523B (zh) | 应用模块与账户的关联方法、关联装置、硬件装置和介质 | |
CN108021399B (zh) | 便签处理方法、装置、设备及存储介质 | |
CN111526084A (zh) | 信息处理方法、装置、设备及存储介质 | |
CN112988822A (zh) | 数据查询方法、装置、设备、可读存储介质以及产品 | |
CN111680248A (zh) | 一种生成消息的推送批次号的方法及装置 | |
CN111061633A (zh) | 一种网页首屏时间检测方法、装置、终端及介质 | |
CN112462996B (zh) | 服务信息优化方法、服务信息优化装置及存储介质 | |
CN113191792B (zh) | 任务的处理方法、装置、电子设备、存储介质和程序产品 | |
CN115484471B (zh) | 主播推荐方法及装置 | |
CN113157703B (zh) | 数据的查询方法、装置、电子设备和存储介质 | |
CN112102081B (zh) | 生成区块链的方法、装置、可读存储介质及区块链网络 | |
CN111241097B (zh) | 处理对象的方法、处理对象的装置及存储介质 | |
CN118172093A (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 |