一种数据分配方法、设备和计算机存储介质
技术领域
本发明涉及网络技术领域,尤其涉及一种数据分配方法、设备和计算机存储介质。
背景技术
随着移动终端与互联网的普及,人们互相交换信息的方式也在不断改变。目前,有很多能够建立社交群组的社交工具,人们通过社交群组互相交换信息,了解最新的咨询,通过社交群组进行沟通已经成为人们相互间进行沟通的重要手段。通过社交群组,用户可以分享照片、文本、音频和视频等数据,无论是日常的工作群组还是用作资源共享的群组,每一个群组成员都可以在群组中进行分享。
但是,在社交群组中分享的数据需要在每个群组成员的终端设备上均存储一份,导致这些共享的信息在每个群组成员的手机上都存了大量的副本,从整个社交群组来看,同样的数据产生了大量的拷贝。然而,每个人的手机存储空间有限,造成了存储资源的极大浪费。
发明内容
本发明的主要目的在于提出一种数据分配方法、设备和计算机存储介质,旨在解决群组数据存储资源的浪费,实现了数据存储的去中心化。
为达到上述目的,本发明的技术方案是这样实现的:
第一方面,本发明实施例提供了一种数据分配方法,所述方法包括:
根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据;
建立所述群组中每个群成员终端与所存入的群组数据的对应关系;
接收所述群组中的第一群成员终端发送的搜索请求;其中,所述搜索请求用于指示期望的待搜索数据;所述第一群成员终端为群组中的任一终端;
根据所述群组中每个群成员终端与所存入的群组数据的对应关系确定存储所述待搜索数据的第二群成员终端;
从所述第二群成员终端中获取所述待搜索数据,并将所述待搜索数据发送至所述第一群成员终端。
可选地,所述根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据,包括:
检测所述群组中每个群成员的终端所对应的剩余存储空间;
将所述每个群成员的终端所对应的剩余存储空间进行排序;
根据所述每个群成员的终端所对应的剩余存储空间排序结果对所述群组数据进行分配,将所分配的每一部分群组数据分别存储在所述群组中的不同群成员的终端中;其中,所述每个群成员的终端所对应的剩余存储空间与存入的群组数据量成正比。
可选地,所述方法还包括:
当接收到群组数据时,根据所述群组数据生成群组数据索引;
将所述群组数据索引保存至所述群组中每个群成员的终端中。
可选地,所述当接收到群组数据时,根据所述群组数据生成群组数据索引,包括:
当接收到群组数据时,将所述群组数据进行分类;
按照预设的群组数据索引设置策略,对分类后的群组数据分别设置群组数据索引。
可选地,所述第一群成员终端发送的搜索请求中携带所述待搜索数据所对应的群组数据索引信息。
可选地,所述根据所述群组中每个群成员终端与所存入的群组数据的对应关系确定存储所述待搜索数据的第二群成员终端,包括:
查找与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据;
根据所述与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据,在所述群组中每个群成员终端与所存入的群组数据的对应关系中查找所述存储所述待搜索数据的第二群成员终端。
可选地,所述方法还包括:
统计所述第一群成员终端搜索群组数据的搜索频率;
当检测到所述第一群成员终端搜索任一群组数据的搜索频率高于预设的频率阈值时,将搜索频率高于预设的频率阈值的待搜索数据存入所述第一群成员终端中。
可选地,在将所述待搜索数据发送至所述第一群成员终端之后,所述方法还包括:
按照预设的提示方式对所述第一群成员终端进行提醒。
第二方面,本发明实施例提供了一种数据分配设备,所述设备包括处理器和存储器;
所述存储器,配置为存储数据分配程序;
所述处理器,配置为执行存储器中存储的数据分配程序,以实现第一方面中记载的数据分配方法的步骤。
第三方面,本发明实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质上存储有数据分配程序,所述数据分配程序被处理器执行时实现第一方面中记载的数据分配方法的步骤。
本发明实施例所提供的一种数据分配方法、设备和计算机存储介质,根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据,并建立群组中每个群成员终端与所存入的群组数据的对应关系,然后,接收群组中的第一群成员终端发送的搜索请求,根据群组中每个群成员终端与所存入的群组数据的对应关系确定存储待搜索数据的第二群成员终端,最后,从第二群成员终端中获取待搜索数据,并将待搜索数据发送至第一群成员终端避免了群组数据存储资源的浪费,分散存储实现了数据存储的去中心化。
附图说明
图1为本发明实施例提供的一种移动终端的硬件结构示意图;
图2为本发明实施例提供的移动终端能够操作的通信***结构示意图;
图3为本发明实施例一提供的一种数据分配方法流程示意图一;
图4为本发明实施例一提供的一种数据分配方法流程示意图二;
图5为本发明实施例一提供的群组成员发起搜索请求的输入界面示意图;
图6为本发明实施例一提供的管理终端接收搜索请求的界面示意图;
图7为本发明实施例一提供的一种数据分配方法流程示意图三;
图8为本发明实施例一提供的搜索到的群组消息的提示界面示意图;
图9为本发明实施例二提供的一种数据分配方法具体实现流程示意图;
图10为本发明实施例三提供的一种数据分配设备硬件实体结构示意图。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯***)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作***、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作***、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理***与处理器110逻辑相连,从而通过电源管理***实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络***进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络***架构图,该通信网络***为通用移动通信技术的LTE***,该LTE***包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子***)或其它IP业务等。
虽然上述以LTE***为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE***,也可以适用于其他无线通信***,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络***等,此处不做限定。
基于上述移动终端硬件结构以及通信网络***,提出本发明方法各个实施例。
实施例一
参见图3,其示出了本发明实施例提供的一种数据分配方法,所述方法应用于群组中的管理终端,所述管理终端为群组中的任一终端,所述方法包括:
S101、管理终端根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据。
需要说明的是,管理终端是指:群组中的任一群组成员所对应的终端。将群组中任意一个群组成员所对应的终端设置为管理终端,对群组中的数据进行管理。也就是说,群组中任何一个终端都可以作为管理终端对群组数据进行管理和分配,在群组中没有一个固定的终端作为群组的中心,任何群成员的终端都能够作为群组的中心对群组数据进行管理。
群成员在群组中分享的数据包括:照片、语音、文本和视频等数据,这些群组数据会占用群组中每个群成员接收终端的存储空间。将群组数据分成若干个部分,每个部分分别存储在群组成员的终端中。这样,每个群组成员终端中分别存储一部分群组数据,避免了每个群成员终端都存入所有的群组数据。
参见图4,S101具体包括S1011至S1013:
S1011、所述管理终端检测所述群组中每个群成员的终端所对应的剩余存储空间。
需要说明的是,群组中所有群成员的终端所剩余的存储空间均不相同,管理终端检测群组中所有群成员的终端的剩余存储空间,目的是为了根据群组中所有群组成员剩余的存储容量来决定如何存储群组数据。
S1012、所述管理终端将所述每个群成员的终端所对应的剩余存储空间进行排序。
需要说明的是,管理终端将群组中所有成员的终端的存储空间进行排序,目的是为了方便根据群组中各成员的终端的所对应的剩余存储空间对群组数据进行分配。
举例来说,群组中有三个终端,分别为终端1、终端2和终端3,终端1为管理终端,终端2和终端3为群组中群成员终端。终端1检测其自身以及终端2和终端3的存储空间,将终端1、终端2和终端3的存储空间进行排序。
S1013、所述管理终端根据所述每个群成员的终端所对应的剩余存储空间排序结果对所述群组数据进行分配,将所分配的每一部分群组数据分别存储在所述群组中的不同群成员的终端中;其中,所述每个群成员的终端所对应的剩余存储空间与存入的群组数据量成正比。
需要说明的是,管理终端根据群组中所有成员的存储空间的排序结果来存储群组数据。举例来说,以群主的终端作为管理终端来检测群组中所有成员的终端的剩余存储空间,存储空间剩余多的群组成员对应的终端多分配些数据,存储空间剩余少的群组成员对应的终端少分配些数据。
对于上述步骤S1012中的三个终端,终端1、终端2和终端3剩余存储空间排序结果为:终端1的剩余存储空间最多,终端2的剩余存储空间次之,终端3的剩余存储空间最少。这样,作为管理终端的终端1将群组数据按照剩余存储空间排序结果进行分配:终端1所分配到的群组数据占比最大,终端2所分配到的群组数据占比次之,终端3所分配到的群组数据占比最小。
通过上述步骤S1011至S1013使得群组数据均衡的存储在每一个群成员的终端中,将群组数据分摊在每一个群组成员的终端中,避免了每一个群成员都需要存入一份群组数据副本的情况。
对于图3所示的技术方案,所述方法还包括:
当所述管理终端接收到群组数据时,根据群组数据生成数据索引;以及,
所述管理终端将群组数据索引保存至所述群组中每个群成员的终端中。
在上述过程中,当管理终端接收到群组数据时,根据群组数据生成数据索引,具体包括以下步骤:
当所述管理终端接收到群组数据时,将所述群组数据进行分类;
所述管理终端按照预设的群组数据索引设置策略,对分类后的群组数据分别设置群组数据索引。
需要说明的是,群组数据索引包括:图片缩略图、标签、数据发布时间、关键字等。当管理终端接收到群组数据时,会根据接收到的群组数据类型分别生成不同类型的索引。
举例来说,若接收到的群组数据为文本,则可以根据文本消息生成关键字作为本条文本消息的索引。
若接收到的群组数据为语音或视频,则可以给语音或视频消息加上标签,以语音或视频消息所对应的标签作为索引。
若接收到的群组数据为照片,则可以生成接收到的照片的缩略图,将照片缩略图作为索引。
上述每一种群组数据类型的索引均可以加上数据发布时间使得通过索引查询群组数据更加精确。
通过上述部分的处理过程,管理终端完成了对群组数据的储存。
S102、所述管理终端建立所述群组中每个群成员终端与所存入的群组数据的对应关系。
需要说明的是,由于每个群组成员都存入了一定数量的群组数据,并且每个群组成员存入的群组数据均不相同,因此,建立群组中每个群成员终端与所存入的群组数据的对应关系,以便快速并准确的找到群组数据的所存入的位置信息。
S103、所述管理终端接收所述群组中的第一群成员终端发送的搜索请求;其中,所述搜索请求用于指示期望的待搜索数据;所述第一群成员终端为群组中的任一终端。
这里,所述第一群成员终端发送的搜索请求中携带所述待搜索数据所对应的群组数据索引信息。当群成员需要查阅群组中的历史群组数据时,可以向管理终端发起搜索请求,以便访问想要查阅的群组数据。以搜索请求为载体,携带被搜索群组数据的群组数据索引信息。
需要说明的是,发起搜索的终端为群组中任一群成员的终端,群组中任一群成员的终端发起搜索请求就可以在线访问被搜索的群组数据。而管理终端接收到发起搜索请求的群组成员终端发起的搜索请求后,会在群组数据索引中找到被搜索的群组数据的位置信息,然后将被搜索的群组数据返回给发起搜索请求的终端。
参见图5,其示出了群组成员发起搜索请求的输入界面:
图5为数据索引输入界面的主菜单,发起搜索的群组成员通过终端2可以在主菜单中的四个选项中分别选择关键字、消息发布时间、缩略图和消息标签。点击进入这四个菜单选项后可以查看对应的关键字、消息发布时间、缩略图和消息标签组成的数据索引。选定数据索引后发送搜索请求消息给管理终端搜索数据索引所对应的群组数据。
参见图6,其示出了管理终端接收搜索请求的界面图:
图6为接收搜索请求界面的主菜单,在该界面中列出了群成员中各群组成员终端发送的搜索请求。作为管理终端的群成员可以通过该界面点击进入每一个搜索请求查看群成员具体搜索的信息,也可以忽略该界面,管理终端后台直接对搜索请求进行处理。
S104、所述管理终端根据所述群组中每个群成员终端与所存入的群组数据的对应关系确定存储所述待搜索数据的第二群成员终端。
参见图7,S104具体包括S1041和S1042:
S1041、所述管理终端查找与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据;
S1042、所述管理终根据所述与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据,在所述群组中每个群成员终端与所存入的群组数据的对应关系中查找所述存储所述待搜索数据的第二群成员终端。
需要说明的是,管理终端根据群组数据索引查找与该群组数据索引相匹配的群组数据,然后通过已经建立好的群组中每个群成员终端与所存入的群组数据的对应关系查找发起搜索的终端期望搜索的数据所在的终端。这样管理终端就可以从发起搜索的终端期望搜索的群组数据所在的终端获取相应的群组数据。
通过上述部分,管理终端就获取到了发起搜索的群组终端期望搜索的群组数据。
S105、管理终端从所述第二群成员终端中获取所述待搜索数据,并将所述待搜索数据发送至所述第一群成员终端。
通过上述步骤S105,管理终端将与搜索请求所对应的群组数据发送到群组中发起搜索的群成员终端,此时,管理终端完成了群组数据的发送。
在所述管理终端将所述待搜索数据发送至所述第一群成员终端之后,所述方法还包括:
所述管理终端按照预设的提示方式对所述第一群成员终端进行提醒。
需要说明的是,管理终端发送群组数据给发起搜索的群成员终端后,根据预设的提示方式对发起搜索的群成员终端进行提醒,以便与群组中当前消息界面的消息进行区分。
参见图8,其示出了搜索到的群组消息的提示界面。作为管理终端的终端1在搜索到的群组数据中加上特殊符号返回群组成员的终端2,并且将搜索到的群组数据置顶显示与当前消息界面的群组数据加以区分。在图8中,返回的群组数据前面加上特殊符号“☆”,有“☆”标识的为管理终端返回的群组数据。
对于图3所示的技术方案,所述方法还包括:
所述管理终端统计所述第一群成员终端搜索群组数据的搜索频率;以及,
所述管理终端当检测到所述第一群成员终端搜索任一群组数据的搜索频率高于预设的频率阈值时,将搜索频率高于预设的频率阈值的待搜索数据存入所述第一群成员终端中。
举例来说,作为管理终端的终端1检测到群组成员中的终端2搜索群组数据A的频率高于了预设的频率阈值,群组数据A存在终端3中。那么,终端1就将群组数据A存入终端2,这样终端2就可以在本地访问到群组数据A,免去了在线访问的过程。
同时,终端1也修订群组数据索引中群组数据A的数据索引对应的存储位置信息,将数据索引中群组数据A的存储位置信息由终端3改为终端2。
本发明实施例所提供的一种数据分配方法,根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据,并建立群组中每个群成员终端与所存入的群组数据的对应关系,然后,接收群组中的第一群成员终端发送的搜索请求,根据群组中每个群成员终端与所存入的群组数据的对应关系确定存储待搜索数据的第二群成员终端,最后,从第二群成员终端中获取待搜索数据,并将待搜索数据发送至第一群成员终端避免了群组数据存储资源的浪费,分散存储实现了数据存储的去中心化。
实施例二
基于前述实施例相同的技术构思,参见图9,其示出了本发明实施例提供的一种数据分配方法的具体实现流程,该流程可以包括:
S201、检测群组中每个群成员的终端所对应的剩余存储空间。
S202、将每个群成员的终端所对应的剩余存储空间进行排序。
S203、根据每个群成员的终端所对应的剩余存储空间排序结果对群组数据进行分配,将所分配的每一部分群组数据分别存储在群组中的不同群成员的终端中;其中,每个群成员的终端所对应的剩余存储空间与存入的群组数据量成正比。
通过上述步骤S201至S203将群组数据分别存储在所述群组中每个群成员的终端中,使得剩余存储空间越大的终端存入的群组数据越多,剩余存储空间越小的终端存入的群组数据越少。这样,实现了群组数据的负载均衡,将群组数据分散的存储在了群组成员的每个终端中。
S204、当接收到群组数据时,将群组数据进行分类。
S205、按照预设的群组数据索引设置策略,对分类后的群组数据分别设置群组数据索引。
S206、将群组数据索引保存至群组中每个群成员的终端中。
上述步骤S204至S206生成了群组数据索引,并且将群组数据索引分别存入每一个群组成员终端,这样,每个群组成员的终端就只需要存储群组数据索引,而不用保存全部的群组数据。
S207、建立群组中每个群成员终端与所存入的群组数据的对应关系。
需要说明的是,管理终端建立群组中每个群成员终端与所存入的群组数据的对应关系,使得在生成群组数据索引之后,通过群组数据索引所对应的群组数据所存入的终端,就能定位出群组数据所在位置。
S208、接收群组中的第一群成员终端发送的搜索请求;其中,搜索请求用于指示期望的待搜索数据;第一群成员终端为群组中的任一终端。
S209、查找与待搜索数据所对应的群组数据索引信息相匹配的群组数据。
S210、根据与待搜索数据所对应的群组数据索引信息相匹配的群组数据,在群组中每个群成员终端与所存入的群组数据的对应关系中查找所述存储所述待搜索数据的第二群成员终端。
S211、统计第一群成员终端搜索群组数据的搜索频率。
S212、将第一群成员终端搜索任一群组数据的搜索频率与预设的频率阈值进行比较;当检测到第一群成员终端搜索任一群组数据的搜索频率高于预设的频率阈值时,执行步骤S213;当检测到第一群成员终端搜索任一群组数据的搜索频率低于或者等于预设的频率阈值时,执行步骤S214。
S213、当检测到第一群成员终端搜索任一群组数据的搜索频率高于预设的频率阈值时,将搜索频率高于预设的频率阈值的待搜索数据存入第一群成员终端中。
S214、当检测到第一群成员终端搜索任一群组数据的搜索频率低于或者等于预设的频率阈值时,将搜索频率低于或者等于预设的频率阈值的待搜索数据保存在原来的群组成员终端中。
通过上述步骤S211至S214完成了群组数据存储方式的优化,使得被搜索频率高的群组数据存在发起搜索该群组数据频率最高的终端中。如此,当发起搜索频率最高的终端再搜索该群组数据时可以从本地获得,而不用通过网络在线获取。
同时,管理终端也修订群组数据索引所对应的已经改变存储终端的群组数据的存储位置信息。
S215、从第二群成员终端中获取待搜索数据,并将待搜索数据发送至第一群成员终端。
S216、按照预设的提示方式对第一群成员终端进行提醒。
通过上述步骤S215至S216,管理终端将群组数据发送到了发起搜索请求的群成员终端中,并在发送群组数据的同时对发起搜索的群成员终端进行提醒,以便群组成员能及时查看信息,并将搜索数据与群组中当前所显示的消息加以区分。
本发明实施例所提供的一种数据分配方法,根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据,并建立群组中每个群成员终端与所存入的群组数据的对应关系,然后,接收群组中的第一群成员终端发送的搜索请求,根据群组中每个群成员终端与所存入的群组数据的对应关系确定存储待搜索数据的第二群成员终端,最后,从第二群成员终端中获取待搜索数据,并将待搜索数据发送至第一群成员终端避免了群组数据存储资源的浪费,分散存储实现了数据存储的去中心化。
实施例三
基于前述实施例相同的技术构思,参见图10,其示出了本发明实施例提供的一种数据分配设备10,所述数据分配设备10包括处理器1001和存储器1002;
所述存储器1002,配置为存储数据分配程序;
所述处理器1001,配置为执行存储器1002中存储的数据分配程序,以实现以下步骤:
根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据;
建立所述群组中每个群成员终端与所存入的群组数据的对应关系;
接收所述群组中的第一群成员终端发送的搜索请求;其中,所述搜索请求用于指示期望的待搜索数据;所述第一群成员终端为群组中的任一终端;
根据所述群组中每个群成员终端与所存入的群组数据的对应关系确定存储所述待搜索数据的第二群成员终端;
从所述第二群成员终端中获取所述待搜索数据,并将所述待搜索数据发送至所述第一群成员终端。
在实际应用中,上述存储器1002可以是易失性存储器(volatile memory),例如随机存取存储器(RAM,Random-Access Memory);或者非易失性存储器(non-volatilememory),例如只读存储器(ROM,Read-Only Memory),快闪存储器(flash memory),硬盘(HDD,Hard Disk Drive)或固态硬盘(SSD,Solid-State Drive);或者上述种类的存储器的组合,并向处理器1001提供指令和数据。
上述处理器1001可以为特定用途集成电路(ASIC,Application SpecificIntegrated Circuit)、DSP、数字信号处理装置(DSPD,Digital Signal ProcessingDevice)、可编程逻辑装置(PLD,Programmable Logic Device)、FPGA、CPU、控制器、微控制器、微处理器中的至少一种。可以理解地,对于不同的设备,用于实现上述处理器功能的电子器件还可以为其它,本发明实施例不作具体限定。
优选地,所述处理器1001,具体可以用于:
检测所述群组中每个群成员的终端所对应的剩余存储空间;
将所述每个群成员的终端所对应的剩余存储空间进行排序;
根据所述每个群成员的终端所对应的剩余存储空间排序结果对所述群组数据进行分配,将所分配的每一部分群组数据分别存储在所述群组中的不同群成员的终端中;其中,所述每个群成员的终端所对应的剩余存储空间与存入的群组数据量成正比。
优选地,所述处理器1001,具体可以用于:
当接收到群组数据时,根据所述群组数据生成群组数据索引;
将所述群组数据索引保存至所述群组中每个群成员的终端中。
优选地,所述处理器1001,具体可以用于:
当接收到群组数据时,将所述群组数据进行分类;
按照预设的群组数据索引设置策略,对分类后的群组数据分别设置群组数据索引。
优选地,所述处理器1001,具体可以用于:
在所述第一群成员终端发送的搜索请求中携带所述待搜索数据所对应的群组数据索引信息。
优选地,所述处理器1001,具体可以用于:
查找与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据;
根据所述与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据,在所述群组中每个群成员终端与所存入的群组数据的对应关系中查找所述存储所述待搜索数据的第二群成员终端。
优选地,所述处理器1001,具体可以用于:
统计所述第一群成员终端搜索群组数据的搜索频率;
当检测到所述第一群成员终端搜索任一群组数据的搜索频率高于预设的频率阈值时,将搜索频率高于预设的频率阈值的所述第一数据存入所述第一群成员终端中。
优选地,所述处理器1001,具体可以用于:
按照预设的提示方式对所述第一群成员终端进行提醒。
本发明实施例所提供的一种数据分配设备,根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据,并建立群组中每个群成员终端与所存入的群组数据的对应关系,然后,接收群组中的第一群成员终端发送的搜索请求,根据群组中每个群成员终端与所存入的群组数据的对应关系确定存储待搜索数据的第二群成员终端,最后,从第二群成员终端中获取待搜索数据,并将待搜索数据发送至第一群成员终端避免了群组数据存储资源的浪费,分散存储实现了数据存储的去中心化。
实施例四
本发明实施例还提供一种计算机可读存储介质,本实施例中的一种数据分配方法对应的计算机程序指令可以被存储在光盘,硬盘,U盘等存储介质上,当存储介质中的与一种数据分配方法对应的计算机程序指令被一电子设备读取或被执行时,包括如下步骤:
根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据;
建立所述群组中每个群成员终端与所存入的群组数据的对应关系;
接收所述群组中的第一群成员终端发送的搜索请求;其中,所述搜索请求用于指示期望的待搜索数据;所述第一群成员终端为群组中的任一终端;
根据所述群组中每个群成员终端与所存入的群组数据的对应关系确定存储所述待搜索数据的第二群成员终端;
从所述第二群成员终端中获取所述待搜索数据,并将所述待搜索数据发送至所述第一群成员终端
可选的,存储介质中存储的与步骤:根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据,包括:
检测所述群组中每个群成员的终端所对应的剩余存储空间;
将所述每个群成员的终端所对应的剩余存储空间进行排序;
根据所述每个群成员的终端所对应的剩余存储空间排序结果对所述群组数据进行分配,将所分配的每一部分群组数据分别存储在所述群组中的不同群成员的终端中;其中,所述每个群成员的终端所对应的剩余存储空间与存入的群组数据量成正比。
可选的,存储介质中存储的与步骤还包括:
当接收到群组数据时,根据所述群组数据生成群组数据索引;
将所述群组数据索引保存至所述群组中每个群成员的终端中。
可选的,存储介质中存储的与步骤:当接收到群组数据时,根据所述群组数据生成群组数据索引,包括:
当接收到群组数据时,将所述群组数据进行分类;
按照预设的群组数据索引设置策略,对分类后的群组数据分别设置群组数据索引。
可选的,存储介质中存储的与步骤还包括:
所述第一群成员终端发送的搜索请求中携带所述待搜索数据所对应的群组数据索引信息。
可选的,存储介质中存储的与步骤:根据所述群组中每个群成员终端与所存入的群组数据的对应关系确定存储所述待搜索数据的第二群成员终端,包括:
查找与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据;
根据所述与所述待搜索数据所对应的群组数据索引信息相匹配的群组数据,在所述群组中每个群成员终端与所存入的群组数据的对应关系中查找所述存储所述待搜索数据的第二群成员终端。
可选的,存储介质中存储的与步骤还包括:
统计所述第一群成员终端搜索群组数据的搜索频率;
当检测到所述第一群成员终端搜索任一群组数据的搜索频率高于预设的频率阈值时,将搜索频率高于预设的频率阈值的待搜索数据存入所述第一群成员终端中。
可选的,存储介质中存储的与步骤:在将所述待搜索数据发送至所述第一群成员终端之后,还包括:
按照预设的提示方式对所述第一群成员终端进行提醒。
本发明实施例所提供的一种计算机存储介质,根据预设的负载均衡策略,在群组中每个群成员的终端中分别存入不同的群组数据,并建立群组中每个群成员终端与所存入的群组数据的对应关系,然后,接收群组中的第一群成员终端发送的搜索请求,根据群组中每个群成员终端与所存入的群组数据的对应关系确定存储待搜索数据的第二群成员终端,最后,从第二群成员终端中获取待搜索数据,并将待搜索数据发送至第一群成员终端避免了群组数据存储资源的浪费,分散存储实现了数据存储的去中心化。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。