CN107317855B - 一种数据缓存方法、数据请求方法及服务器 - Google Patents
一种数据缓存方法、数据请求方法及服务器 Download PDFInfo
- Publication number
- CN107317855B CN107317855B CN201710473412.0A CN201710473412A CN107317855B CN 107317855 B CN107317855 B CN 107317855B CN 201710473412 A CN201710473412 A CN 201710473412A CN 107317855 B CN107317855 B CN 107317855B
- Authority
- CN
- China
- Prior art keywords
- cache
- parameter information
- target
- interface
- value corresponding
- 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
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/56—Provisioning of proxy services
- H04L67/568—Storing data temporarily at an intermediate stage, e.g. caching
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/56—Provisioning of proxy services
- H04L67/568—Storing data temporarily at an intermediate stage, e.g. caching
- H04L67/5682—Policies or rules for updating, deleting or replacing the stored data
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Mobile Radio Communication Systems (AREA)
- Telephone Function (AREA)
Abstract
本发明公开了一种数据缓存方法、数据请求方法及服务器,所述数据缓存方法接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的缓存值;若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。这样,本发明提供的数据缓存方法能够有效避免高并发对数据库造成冲击,提升服务器对移动终端的访问请求的响应速度,增强用户体验。
Description
技术领域
本发明涉及通信技术领域,尤其涉及一种数据缓存方法、数据请求方法及服务器。
背景技术
移动终端(例如智能手机、平板电脑等)在使用互联网应用时,都需要从服务器获取数据,并显示在应用界面中。当瞬时访问某个应用的用户数量较大时,即一个高并发场景,此时很可能导致在短时间内有大量的访问涌入数据库。而数据库在短时间内能接受的访问数量是有限的,就很可能导致用户的访问卡顿,甚至导致数据库崩溃,进而导致用户无法正常使用应用。
举例而言,当应用中心推出一款新的应用或者做一个推广活动时,如果访问的用户数量较大,就很可能导致用户在应用中心的相关页面中长时间看不到应用或者活动介绍,甚至导致用户在应用中心中看到空白页,无法进行任何操作。
可见,如何避免高并发对数据库造成冲击成为亟待解决的问题。
发明内容
有鉴于此,本发明提出一种数据缓存方法、数据请求方法及服务器,以解决上述技术问题。
首先,为实现上述目的,本发明提出一种数据缓存方法,应用于服务器,所述方法包括:
接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;
判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值;
若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。
可选地,所述方法还包括:
获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中所述第一缓存值。
可选地,所述方法还包括:
若所述两个缓存区中有一个缓存区缓存与所述非分页参数信息对应的目标缓存值,判断所述目标缓存值是否为预占值;
若所述目标缓存值为预占值,启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
可选地,所述方法还包括:
接收对目标接口对应的缓存值的更新请求;
根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区;
删除更新前的缓存值。
此外,为实现上述目的,本发明还提供一种数据请求方法,应用于移动终端,所述方法包括:
向服务器发送接口请求;
接收所述服务器发送的与所述接口请求对应的目标数据,其中,所述目标数据为所述服务器通过上述数据缓存方法进行缓存或者更新的缓存值。
此外,为实现上述目的,本发明还提供一种服务器,所述服务器包括:
第一接收模块,用于接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;
第一判断模块,用于判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值;
第一缓存模块,用于若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。
可选地,所述服务器还包括:
第二缓存模块,用于获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中的所述第一缓存值。
可选地,所述服务器还包括:
第二判断模块,若所述两个缓存区中有一个缓存区缓存与所述非分页参数信息对应的目标缓存值,判断所述目标缓存值是否为预占值;
控制模块,用于若所述目标缓存值为预占值,启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
可选地,所述服务器还包括:
第二接收模块,用于接收对目标接口对应的缓存值的更新请求;
更新模块,用于根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区;
删除模块,用于删除更新前的缓存值。
此外,为实现上述目的,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可执行的至少一个程序,所述至少一个程序被所述计算机执行时使所述计算机执行上述方法中的步骤。
相较于现有技术,本发明所提出的数据缓存方法,接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的缓存值;若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。这样,本发明提供的数据缓存方法能够有效避免高并发对数据库造成冲击,提升服务器对移动终端的访问请求的响应速度,增强用户体验。
附图说明
图1是实现本发明各个实施例的一种移动终端的硬件结构示意图;
图2是本发明实施例提供的一种通信网络系统架构图;
图3是本发明实施例提供的一种服务器的硬件结构示意图;
图4是本发明实施例提供的一种数据缓存方法的流程示意图;
图5是本发明实施例提供的缓存区示意图;
图6是本发明实施例提供的读取数据的流程示意图;
图7是本发明实施例提供的一种缓存区缓存数据的示意图;
图8是本发明实施例提供的另一种缓存区缓存数据的示意图;
图9是本发明实施例提供的另一种数据缓存方法的流程示意图;
图10是本发明实施例提供的另一种数据缓存方法的流程示意图;
图11是本发明实施例提供的一种服务器的功能模块示意图;
图12为本发明实施例提供的另一种服务器的功能模块示意图;
图13为本发明实施例提供的另一种服务器的功能模块示意图;
图14为本发明实施例提供的另一种服务器的功能模块示意图;
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(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 ofMobile 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(EvolvedUMTS 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,图3是本发明实施例提供的一种服务器的硬件结构示意图,如图3所示,所述服务器包括:处理器300、收发机310、存储器320、用户接口330和总线接口,所述处理器300,用于读取存储器320中的程序。在图3中,总线架构可以包括任意数量的互联的总线和桥,具体由处理器300代表的一个或多个处理器和存储器320代表的存储器的各种电路链接在一起。总线架构还可以将诸如外围设备、稳压器和功率管理电路等之类的各种其他电路链接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口提供接口,收发机310可以是多个元件,即包括发送机和接收机,提供用于在传输介质上与各种其他装置通信的单元。针对不同的用户设备,用户接口330还可以是能够外接内接需要设备的接口,连接的设备包括但不限于小键盘、显示器、扬声器、麦克风、操纵杆等。
处理器300负责管理总线架构和通常的处理,存储器320可以存储处理器300在执行操作时所使用的数据。
基于上述移动终端100硬件结构、通信网络系统以及服务器硬件结构,提出本发明方法各个实施例。
参阅图4,图4是本发明实施例提供的一种数据缓存方法的步骤流程图,所述数据缓存方法应用于一服务器中,如图4所示,所述数据缓存方法包括:
步骤401、接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息。
该实施例中,当用户需要访问服务器获取数据时,用户可以使用移动终端向所述服务器发送接口请求,用于请求获取数据。具体地,用户可以使用移动终端通过HTTP接口来访问服务器获取数据。该步骤中,所述服务器接收所述移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息。
所述非分页参数信息包括接口名称以及非分页接口参数值。具体地,所述服务器在接收到所述接口请求之后,获取所述接口请求中的接口名称以及接口参数值,然后过滤掉所述接口参数值中的分页参数值,得到非分页参数值。
本发明实施例中,所述服务器根据接口名称以及非分页接口参数值进行缓存键的编码,并将对应的缓存数据存在一个哈希表内。举例而言,当一个接口名称是搜索商品SearchGoods时,其传入的参数是商品名称“运动鞋”,页码1时,所述服务器设置该搜索的缓存键为“SearchGoods_name_运动鞋”。
步骤402、判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值。
所述服务器使用至少两个缓存区进行数据缓存,本发明实施例中,以使用两个缓存区进行数据缓存为例进行说明,但并不以此为限。参阅图5,所述服务器可以使用如图5所示的第一缓存区501以及第二缓存区502两个缓存区进行数据缓存。
所述第一缓存区501以及所述第二缓存区502可以分布在同一个缓存集群中实现,也可以分布在两个缓存集群中,所述服务器使用两个缓存区进行数据缓存可以根据两个缓存区的分布情况配置相关参数。具体地,当所述第一缓存区501以及所述第二缓存区502分布在同一个缓存集群中,所述方法可以生成两个缓存哈希表,分别对应所述第一缓存区501以及第二缓存区502,从而实现对所述第一缓存区501以及所述第二缓存区502的区分。当所述第一缓存区501以及所述第二缓存区502分布在两个缓存集群中时,所述方法可以通过不同缓存集群的IP地址来进行缓存区的区分。本发明实施例中的缓存集群可以自适应目前主流的缓存服务,例如Redis(一种数据库)、Memcache(分布式高速缓存系统)。
该步骤中,所述方法判断两个缓存区中是否有一个缓存区中缓存有与所述非分页参数信息对应的目标缓存值,若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,执行步骤403;相反地,若所述两个缓存区中有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值,流程结束。
参阅图6,所述方法判断两个缓存区中是否有一个缓存区中缓存有与所述非分页参数信息对应的目标缓存值的方式具体可以是如图6所示的流程,图6是本发明实施例提供的读取数据的步骤流程图,如图6所示,所述方法读取数据包括:
步骤601、判断第一缓存区中是否有与所述非分页参数信息对应的目标缓存值。若所述第一缓存区中有与所述非分页参数信息对应的目标缓存值,执行步骤602;相反地,若所述第一缓存区中没有与所述非分页参数信息对应的目标缓存值,执行步骤603。
步骤602、返回所述第一缓存区中的所述非分页参数信息对应的目标缓存值,流程结束。
步骤603、判断第二缓存区中是否有与所述非分页参数信息对应的目标缓存值。若所述第二缓存区中有与所述非分页参数信息对应的目标缓存值,执行步骤604;相反地,若所述第二缓存区中没有与所述非分页参数信息对应的目标缓存值,执行步骤605。
步骤604;返回所述第二缓存区中的所述非分页参数信息对应的目标缓存值,流程结束。
步骤605、返回NULL,流程结束。
需要说明的是,图6所示的流程仅仅是以先判断所述第一缓存区中是否有与所述非分页参数信息对应的目标缓存值为例进行说明,但并不以此为限,可以理解的是,所述方法也可以向判断所述第二缓存区中是否有与所述非分页参数信息对应的目标缓存值。
该实施例中,当所述读取缓存数据返回的值为“NULL”时,所述方法确定所述两个缓存区中均没有与所述非分页参数信息对应的目标缓存值,流程进入步骤403;当所述第一缓存区或者所述第二缓存区中有所述非分页参数信息对应的目标缓存值时,流程结束。
步骤403、在第一缓存区中写入预占值作为该非分页参数信息对应的第一缓存值。
该步骤中,所述方法在第一缓存区中写入预占值作为该非分页参数信息对应的第一缓存值。可以理解的,所述方法也可以在第二缓存区中写入预占值,本发明对此不做具体限定,仅仅以在所述第一缓存区中写入预占值为例进行说明。本发明实施例中,所述预占值可以为“WAIT ME”。
该实施例中,所述方法在所述两个缓存区中都没有与所述非分页参数信息对应的目标缓存值时,所述方法在所述第一缓存区中写入预占值作为该非分页参数信息对应的第一缓存值,进一步地,所述方法可以在写入预占值之后获取所述非分页参数信息对应的数据列表并写入缓存。这样,当所述服务器接收到其他相同的接口请求时,可以根据所述预占值进行等待,而不会再触发一次数据获取,从而能够有效地避免高并发情况下对服务区造成冲击,提高访问速度,增强用户体验。
可选地,所述方法还包括:
获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中所述第一缓存值。
该实施例中,若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,所述方法进一步获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中所述第一缓存值。
如图7所示,在获取所述第二缓存值之前,所述非分页参数信息对应的目标缓存值(即第一缓存值)缓存在所述第一缓存区中,在获取到所述第二缓存值时,即所述非分页参数信息对应的目标缓存值从所述第一缓存值更新到第二缓存值时,所述方法将所述第二缓存值写入所述第二缓存区,并删除所述第一缓存区中的所述第一缓存值,如图8所示。
所述非分页参数信息对应的接口允许的最大分页数的数据列表为所述过滤掉所述接口参数值中的分页信息之后对应的数据列表,举例而言,当用户请求获取一个接口名称为搜索商品SearchGoods,商品名称为“运动鞋”,页码为1的数据时,若所述服务器搜索到“SearchGoods_name_运动鞋”对应的页码一共是50页,共1万条数值,所述方法获取所述1万条数值作为所述第二缓存值。
可以理解的是,大部分的接口请求获取的都是分页数据,在高并发场景下,同类接口获取不同分页的数据,可能会存在不同页的数据有重复的问题。为了解决这个问题,对于获取不同分页的同类接口,在生成缓存值时,其键是相同的,而缓存的值则是该接口所允许的最大分页数的数据列表。举例而言,当所述服务器再接收到获取一个接口名称为搜索商品SearchGoods,商品名称为“运动鞋”,页码为5的数据请求时,所述方法可以直接从所述第二缓存区中缓存的第二缓存值中获取对应页码为5的数据,而不需要从服务器里再次获取数据,这样,不管获取哪一页的数据,都不会存在重复数据的问题了。
本发明实施例中,所述数据缓存方法接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的缓存值;若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。这样,本发明提供的数据缓存方法能够有效避免高并发对数据库造成冲击,提升服务器对移动终端的访问请求的响应速度,增强用户体验。
参阅图9,图9是本发明实施例提供的另一种数据缓存方法的步骤流程图,如图9所示,所述方法包括:
步骤901、接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息。
步骤902、判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值,若所述两个缓存区中均没有与所述非分页数参数信息对应的目标缓存值,执行步骤903;相反地,若所述两个缓存区中有一个缓存区中有与所述非分页参数信息对应的目标缓存值,执行步骤904。
步骤903、在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。
所述步骤901至903与本发明图4所示的实施例中步骤401至403相同,此处不再赘述。
步骤904、判断所述目标缓存值是否为预占值,若所述目标缓存值为预占值,执行步骤905;相反地,若所述目标缓存值不为预占值,流程结束。需要说明的是,图9所示的实施例仅仅以流程结束为例,并不以此为限,例如若所述目标缓存值不为预占值,所述方法返回所述目标缓存值并向所述用户终端发送所述目标缓存值。
步骤905、启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
该步骤中,当所述目标缓存为预占值时,说明之前已经有其他的接口请求请求对应的数据,且还没有将数据写入到缓存区中,所述方法启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。这样,所述方法不会再触发一次获取数据,而是等待先前相同的接口请求将对应的缓存值写入缓存区中之后再获取,这样就不需要使用粗粒度的线程锁,能够有效避免高并发情况下对服务器造成冲击,提高用户访问请求的响应速度,增强用户体验。
参见图10,图10是本发明实施例提供的另一种数据缓存方法的步骤流程图,如图10所示,所述方法包括:
步骤1001、接收对目标接口对应的缓存值的更新请求。
该步骤中,所述方法接收对目标接口对应的缓存值的更新请求,所述更新请求可以是用户通过在移动终端上触发,并通过所述移动终端向所述服务器发送的,也可以是管理员直接在后台服务器触发的更新请求,本发明实施例对此不做具体限定。
步骤1002、根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区。
该步骤中,所述方法根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区。
举例而言,假设更新前的缓存值缓存在所述第一缓存区,所述方法将更新后的缓存值写入第二缓存区;相反地,若更新前的缓存值缓存在所述第二缓存区,所述方法将更新后的缓存值写入第一缓存区。
步骤1003、删除更新前的缓存值。
该步骤中,所述方法将更新后的缓存值写入所述目标缓存区之后,删除更新前的缓存值。
这样,缓存值的更新过程不会影响所述移动终端的访问,也进一步避免了高并发下对数据库的冲击。
本发明实施例还提供一种数据请求方法,应用于移动终端,所述方法包括:
向服务器发送接口请求;
接收所述服务器发送的与所述接口请求对应的目标数据,其中,所述目标数据为所述服务器通过上述任意实施例中的方法进行缓存或者更新的缓存值。
参见图11,图11是本发明实施例提供的一种服务器的功能模块示意图,如图11所示,所述服务器1100包括:
第一接收模块1101,用于接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;
第一判断模块1102,用于判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值;
第一缓存模块1103,用于若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。
可选地,参见图12,图12是本发明实施例提供的另一种服务器的功能模块示意图,如图12所示,所述服务器1100还包括:
第二缓存模块1104,用于获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中的所述第一缓存值。
可选地,参见图13,图13是本发明实施例提供的另一种服务器的功能模块示意图,如图13所示,所述服务器1100还包括:
第二判断模块1105,若所述两个缓存区中有一个缓存区缓存与所述非分页参数信息对应的目标缓存值,判断所述目标缓存值是否为预占值;
控制模块1106,用于若所述目标缓存值为预占值,启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
可选地,参见图14,图14是本发明实施例提供的另一种服务器的功能模块示意图,如图14所示,所述服务器1100还包括:
第二接收模块1107,用于接收对目标接口对应的缓存值的更新请求;
更新模块1108,用于根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区;
删除模块1109,用于删除更新前的缓存值。
服务器1100能够上述实施例中服务器实现的各个过程,为避免重复,在此不再赘述。
本领域普通技术人员可以理解实现上述实施例方法的全部或者部分步骤是可以通过至少一个程序指令相关的硬件来完成,所述至少一个程序可以存储于如图3所示的服务器的存储器320中,并能够所述处理器300执行,所述至少一个程序被所述处理器300执行时实现如下步骤:
接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;
判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值;
若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。
可选地,所述处理器300还用于实现如下步骤:
获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中所述第一缓存值。
可选地,所述处理器300还用于实现如下步骤:
若所述两个缓存区中有一个缓存区缓存与所述非分页参数信息对应的目标缓存值,判断所述目标缓存值是否为预占值;
若所述目标缓存值为预占值,启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
可选地,所述处理器300还用于实现如下步骤:
接收对目标接口对应的缓存值的更新请求;
根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区;
删除更新前的缓存值。
本领域普通技术人员可以理解实现上述实施例方法的全部或者部分步骤是可以通过至少一个程序指令相关的硬件来完成,所述至少一个程序可以存储于一计算机可读存储介质中,所述至少一个程序在执行时,包括以下步骤:
接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;
判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值;
若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值。
可选地,所述至少一个程序在执行时,还实现以下步骤:
获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中所述第一缓存值。
可选地,所述至少一个程序在执行时,还实现以下步骤:
若所述两个缓存区中有一个缓存区缓存与所述非分页参数信息对应的目标缓存值,判断所述目标缓存值是否为预占值;
若所述目标缓存值为预占值,启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
可选地,所述至少一个程序在执行时,还实现以下步骤:
接收对目标接口对应的缓存值的更新请求;
根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区;
删除更新前的缓存值。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (8)
1.一种数据缓存方法,应用于服务器,其特征在于,所述方法包括:
接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;
判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值,所述目标缓存值为预占值或者所述非分页参数信息对应的接口允许的最大分页数的数据列表;
若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值;
其中,所述非分页参数信息包括接口名称以及非分页接口参数值;
所述方法还包括:
获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中所述第一缓存值。
2.如权利要求1所述的方法,其特征在于,所述方法还包括:
若所述两个缓存区中有一个缓存区缓存与所述非分页参数信息对应的目标缓存值,判断所述目标缓存值是否为预占值;
若所述目标缓存值为预占值,启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
3.如权利要求1至2任一项所述的方法,其特征在于,所述方法还包括:
接收对目标接口对应的缓存值的更新请求;
根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区;
删除更新前的缓存值。
4.一种数据请求方法,应用于移动终端,其特征在于,所述方法包括:
向服务器发送接口请求;
接收所述服务器发送的与所述接口请求对应的目标数据,其中,所述目标数据为所述服务器通过上述权利要求1至3任一项所述的方法进行缓存或者更新的缓存值。
5.一种服务器,其特征在于,所述服务器包括:
第一接收模块,用于接收移动终端发送的接口请求,并获取所述接口请求中的非分页参数信息;
第一判断模块,用于判断两个缓存区中是否有一个缓存区中缓存与所述非分页参数信息对应的目标缓存值,所述目标缓存值为预占值或者所述非分页参数信息对应的接口允许的最大分页数的数据列表;
第一缓存模块,用于若所述两个缓存区中均没有缓存与所述非分页参数信息对应的目标缓存值,在第一缓存区中写入预占值作为与该非分页参数信息对应的第一缓存值;
其中,所述非分页参数信息包括接口名称以及非分页接口参数值;
所述服务器还包括:
第二缓存模块,用于获取所述非分页参数信息对应的接口允许的最大分页数的数据列表,作为所述非分页参数信息对应的第二缓存值写入第二缓存区,并删除所述第一缓存区中的所述第一缓存值。
6.如权利要求5所述的服务器,其特征在于,所述服务器还包括:
第二判断模块,若所述两个缓存区中有一个缓存区缓存与所述非分页参数信息对应的目标缓存值,判断所述目标缓存值是否为预占值;
控制模块,用于若所述目标缓存值为预占值,启动线程等待,等待先前相同的接口请求将所述非分页参数信息对应的缓存值写完。
7.如权利要求5至6任一项所述的服务器,其特征在于,所述服务器还包括:
第二接收模块,用于接收对目标接口对应的缓存值的更新请求;
更新模块,用于根据所述更新请求更新所述目标接口对应的缓存值,并将所述更新后的缓存值写入目标缓存区,其中,所述目标缓存区为与缓存更新前的缓存值的缓存区不同的缓存区;
删除模块,用于删除更新前的缓存值。
8.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可执行的至少一个程序,其特征在于,所述至少一个程序被所述计算机执行时使所述计算机执行上述权利要求1~3任一项所述的方法中的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710473412.0A CN107317855B (zh) | 2017-06-21 | 2017-06-21 | 一种数据缓存方法、数据请求方法及服务器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710473412.0A CN107317855B (zh) | 2017-06-21 | 2017-06-21 | 一种数据缓存方法、数据请求方法及服务器 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107317855A CN107317855A (zh) | 2017-11-03 |
CN107317855B true CN107317855B (zh) | 2020-09-08 |
Family
ID=60181882
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710473412.0A Active CN107317855B (zh) | 2017-06-21 | 2017-06-21 | 一种数据缓存方法、数据请求方法及服务器 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107317855B (zh) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108282405B (zh) * | 2017-12-27 | 2020-09-18 | 好活(昆山)网络科技有限公司 | 应用程序接口缓存管理方法、应用服务器及存储介质 |
CN109669791A (zh) * | 2018-12-22 | 2019-04-23 | 网宿科技股份有限公司 | 交互方法、服务器及计算机可读存储介质 |
CN109739570B (zh) * | 2018-12-24 | 2022-04-08 | 新华三技术有限公司 | 一种数据读取方法、服务器控制设备、服务器及计算机可读存储介质 |
CN110244912B (zh) * | 2019-06-20 | 2022-06-21 | 上海数据交易中心有限公司 | 数据配送系统的缓存方法 |
CN111240650B (zh) * | 2020-01-22 | 2023-06-30 | 上海钧正网络科技有限公司 | 一种数据分页的方法、装置及移动终端 |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030046394A1 (en) * | 2000-11-03 | 2003-03-06 | Steve Goddard | System and method for an application space server cluster |
CN1238792C (zh) * | 2002-12-18 | 2006-01-25 | 华为技术有限公司 | 一种数据库访问方法及实现该方法的客户机/服务器系统 |
US7941609B2 (en) * | 2007-02-23 | 2011-05-10 | Microsoft Corporation | HTTP acceleration by prediction and pre-fetching |
CN101661459B (zh) * | 2009-10-19 | 2011-08-31 | 中国电信股份有限公司 | 网络文档资源提供方法、平台及系统 |
CN102063441A (zh) * | 2009-11-11 | 2011-05-18 | 北大方正集团有限公司 | 一种信息的发布方法、系统及装置 |
JP2011108102A (ja) * | 2009-11-19 | 2011-06-02 | Sony Corp | ウェブサーバ、ウェブブラウザおよびウェブシステム |
CN102880685B (zh) * | 2012-09-13 | 2015-06-24 | 北京航空航天大学 | 一种时间密集大数据量的b/s分区间分页查询方法 |
CN103995807B (zh) * | 2013-02-16 | 2018-01-16 | 长沙中兴软创软件有限公司 | 一种基于Web架构下海量数据查询和二次处理的方法 |
CN104035923B (zh) * | 2013-03-04 | 2017-09-01 | 阿里巴巴集团控股有限公司 | 查询数据的方法及装置 |
CN105243072A (zh) * | 2014-07-11 | 2016-01-13 | 北京神州泰岳软件股份有限公司 | 一种数据库查询方法及系统 |
CN104573035B (zh) * | 2015-01-16 | 2019-07-23 | 杭州犀照科技有限公司 | 新闻信息获取方法及系统 |
CN105095424A (zh) * | 2015-07-17 | 2015-11-25 | 四川久远银海软件股份有限公司 | 一种实现医院his系统中药品的高并发检索方法 |
-
2017
- 2017-06-21 CN CN201710473412.0A patent/CN107317855B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN107317855A (zh) | 2017-11-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107317855B (zh) | 一种数据缓存方法、数据请求方法及服务器 | |
CN107967322B (zh) | 文件分类显示方法、移动终端及计算机可读存储介质 | |
CN107038245B (zh) | 页面切换方法、移动终端及存储介质 | |
CN107688607A (zh) | 一种数据库访问的方法及移动终端、计算机可读存储介质 | |
CN107749919B (zh) | 一种应用程序页面显示方法、设备及计算机可读存储介质 | |
CN107562705B (zh) | 一种数据导出方法、服务端及计算机可读存储介质 | |
CN107124466B (zh) | 一种防止缓存穿透方法及装置、计算机可读存储介质 | |
CN107862217B (zh) | 一种位置信息获取方法、移动终端以及计算机存储介质 | |
CN109219004B (zh) | 短信退订方法、装置、移动终端及可读存储介质 | |
CN108600516B (zh) | 数据采集方法、移动终端及计算机可读存储介质 | |
CN108282405B (zh) | 应用程序接口缓存管理方法、应用服务器及存储介质 | |
CN107818022B (zh) | 应用程序接口合并方法、移动终端及计算机可读存储介质 | |
CN112597115A (zh) | 容器镜像的压缩方法、装置、终端设备及介质 | |
CN109683797B (zh) | 一种显示区控制方法、设备及计算机可读存储介质 | |
CN111158617A (zh) | 一种投屏内容同步方法、移动终端及计算机可读存储介质 | |
CN107360211B (zh) | 一种信息流资讯的下线方法、相关设备及计算机存储介质 | |
CN107809527B (zh) | 一种呈现快捷操作的方法和电子设备 | |
CN109062688B (zh) | 一种内存分配方法、服务器及移动终端 | |
CN107404568B (zh) | 一种控制开关管理方法及移动终端 | |
CN111970738A (zh) | 一种网络切换控制方法、设备及计算机可读存储介质 | |
CN108183833B (zh) | 一种响应处理方法、装置及计算机可读存储介质 | |
CN108037959B (zh) | 接口智能合并方法、移动终端及计算机可读存储介质 | |
CN108279985B (zh) | 一种接口请求协议改造方法、设备及计算机可读存储介质 | |
CN109379719B (zh) | 一种应用程序广播处理方法、设备及计算机可读存储介质 | |
CN110058761B (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 | ||
TA01 | Transfer of patent application right | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20200814 Address after: Room 109a, building 2, 333 Hongqiao Road, Xuhui District, Shanghai, 200030 Applicant after: Shanghai Zhichuang Information Technology Co., Ltd Address before: 518057 Guangdong Province, Shenzhen high tech Zone of Nanshan District City, No. 9018 North Central Avenue's innovation building A, 6-8 layer, 10-11 layer, B layer, C District 6-10 District 6 floor Applicant before: NUBIA TECHNOLOGY Co.,Ltd. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |