CN108156252B - 一种数据访问方法、装置、服务器及客户端 - Google Patents

一种数据访问方法、装置、服务器及客户端 Download PDF

Info

Publication number
CN108156252B
CN108156252B CN201810008141.6A CN201810008141A CN108156252B CN 108156252 B CN108156252 B CN 108156252B CN 201810008141 A CN201810008141 A CN 201810008141A CN 108156252 B CN108156252 B CN 108156252B
Authority
CN
China
Prior art keywords
service node
data
response
response data
access request
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
Application number
CN201810008141.6A
Other languages
English (en)
Other versions
CN108156252A (zh
Inventor
魏超凡
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing QIYI Century Science and Technology Co Ltd
Original Assignee
Beijing QIYI Century Science and Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Beijing QIYI Century Science and Technology Co Ltd filed Critical Beijing QIYI Century Science and Technology Co Ltd
Priority to CN201810008141.6A priority Critical patent/CN108156252B/zh
Publication of CN108156252A publication Critical patent/CN108156252A/zh
Application granted granted Critical
Publication of CN108156252B publication Critical patent/CN108156252B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/61Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources taking into account QoS or priority requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/62Establishing a time schedule for servicing the requests
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/63Routing a service request depending on the request content or context

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer And Data Communications (AREA)

Abstract

本发明实施例提供了一种数据访问方法、装置、服务器及客户端,所述数据访问方法,包括:接收客户端发送的数据访问请求,其中,所述数据访问请求携带预设响应时长;确定用于响应所述数据访问请求的服务节点,作为目标服务节点;通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应所述数据访问请求的响应数据;在获得各个目标服务节点所提供响应数据消耗的时长达到所述预设响应时长时,根据所获得的响应数据确定待发送数据,将所述待发送数据发送至所述客户端,以使得所述客户端展示所述待发送数据。以使得用户能够访问其自身想要访问的数据,从而提高用户的体验。

Description

一种数据访问方法、装置、服务器及客户端
技术领域
本发明涉及通信技术领域,特别是涉及一种数据访问方法、一种数据访问装置、一种服务器及一种客户端。
背景技术
用户需要访问网络数据时,一般通过客户端向服务器发送数据访问请求;服务器在接收到客户端发送的数据访问请求后,确定用于响应上述数据访问请求的服务节点,作为目标服务节点,并通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应数据访问请求的响应数据,在获得所有目标服务节点提供的响应数据后,将这些响应数据发送至客户端,客户端接收到服务器发送的响应数据后,展示接收到的响应数据,以使得用户能够访问网络数据。
然而,发明人在实现本发明的过程中发现,现有技术至少存在如下问题:
客户端向服务器发送上述数据访问请求后,一般会期望在一定时长内获得响应数据,而现有技术中,服务器是在获得所有目标服务节点提供的响应数据后,才将所获得的响应数据发送至客户端,受网络状态等因素的影响,服务器获得所有目标服务节点提供的响应数据消耗的时间可能会超过客户端期望的时长。鉴于存在上述情况,客户端在向服务器发送上述数据访问请求后,监测发出上述数据访问请求的时间是否达到其所期望的时长,一旦达到其所期望的时长,还未获得服务器反馈的响应数据,客户端会主动放弃从服务器获得上述数据访问请求的响应数据,并向用户显示“稍后重试”、“请刷新”、“获取数据超时”等数据,从而导致用户不能访问想要访问的数据,用户体验较差。
发明内容
本发明实施例的目的在于提供一种数据访问方法、装置、服务器及客户端,以以使得用户能够访问其自身想要访问的数据,从而提高用户的体验。具体技术方案如下:
第一方面,本发明实施例提供了一种数据访问方法,应用于服务器,所述方法包括:
接收客户端发送的数据访问请求,其中,所述数据访问请求携带预设响应时长;
确定用于响应所述数据访问请求的服务节点,作为目标服务节点;
通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应所述数据访问请求的响应数据;
在获得各个目标服务节点所提供响应数据消耗的时长达到所述预设响应时长时,根据所获得的响应数据确定待发送数据,将所述待发送数据发送至所述客户端,以使得所述客户端展示所述待发送数据。
可选的,所述通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应所述数据访问请求的响应数据,包括:
设置当前服务节点为第一服务节点,并将所述预设响应时长确定为剩余响应时长,其中,所述第一服务节点为:目标服务节点中调用优先级最高的服务节点,所述调用优先级为:根据所述数据访问请求确定的调用各个目标服务节点的优先级;
通过调用所述当前服务节点,获得第一响应数据,其中,所述第一响应数据为:所述当前服务节点提供的、用于响应所述数据访问请求的响应数据;
利用获得所述第一响应数据所消耗的时长,更新所述剩余响应时长;
若所述剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将所述当前服务节点更新为第二服务节点,并返回执行所述通过调用所述当前服务节点,获得第一响应数据的步骤,所述第二服务节点为:调用优先级为目标调用优先级的目标服务节点,所述目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级。
可选的,所述通过调用所述当前服务节点,获得第一响应数据,包括:
通过向所述当前服务节点发送调用请求的方式调用所述当前服务节点,获得第一响应数据,其中,所述调用请求中携带所述剩余响应时长,所述第一响应数据为:所述当前服务节点在所述剩余响应时长内反馈至所述服务器的响应数据。
可选的,所述根据所获得的响应数据确定待发送数据,包括:
判断所获得的响应数据是否为空;
若所获得的响应数据为空,将预设数据确定为待发送数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
第二方面,本发明实施例还提供了一种数据访问方法,应用于客户端,所述方法包括:
向服务器发送数据访问请求,其中,所述数据访问请求携带预设响应时长;
接收所述服务器发送的目标响应数据,其中,所述目标响应数据为:服务器在获得各个目标服务节点所提供响应数据的时长达到所述预设响应时长时,向所述客户端发送的响应数据,所述服务器向所述客户端发送的响应数据为:所述服务器根据各个目标服务节点提供的、用于响应所述数据访问请求的响应数据确定的数据,所述目标服务节点为:用于响应所述数据访问请求的服务节点;
展示所接收的目标响应数据。
可选的,在各个目标服务节点提供的、用于响应所述数据访问请求的响应数据为空的情况下,所述服务器向所述客户端发送的响应数据为预设数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
第三方面,本发明实施例还提供了一种数据访问装置,应用于服务器,所述装置包括:
请求接收模块,用于接收客户端发送的数据访问请求,其中,所述数据访问请求携带预设响应时长;
服务节点确定模块,用于确定用于响应所述数据访问请求的服务节点,作为目标服务节点;
响应数据获取模块,用于通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应所述数据访问请求的响应数据;
数据发送模块,用于在获得各个目标服务节点所提供响应数据消耗的时长达到所述预设响应时长时,根据所获得的响应数据确定待发送数据,将所述待发送数据发送至所述客户端,以使得所述客户端展示所述待发送数据。
可选的,所述响应数据获取模块,包括:
信息确定单元,用于设置当前服务节点为第一服务节点,并将所述预设响应时长确定为剩余响应时长,其中,所述第一服务节点为:目标服务节点中调用优先级最高的服务节点,所述调用优先级为:根据所述数据访问请求确定的调用各个目标服务节点的优先级;
第一响应数据获取单元,用于通过调用所述当前服务节点,获得第一响应数据,其中,所述第一响应数据为:所述当前服务节点提供的、用于响应所述数据访问请求的响应数据;
剩余响应时长更新模块,用于利用获得所述第一响应数据所消耗的时长,更新所述剩余响应时长;
当前服务节点更新单元,用于若所述剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将所述当前服务节点更新为第二服务节点,并返回执行所述通过调用所述当前服务节点,获得所述当前服务节点提供的、用于响应所述数据访问请求的响应数据的步骤,所述第二服务节点为:调用优先级为目标调用优先级的目标服务节点,所述目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级。
可选的,所述第一响应数据获取单元,具体用于:
通过向所述当前服务节点发送调用请求的方式调用所述当前服务节点,获得第一响应数据,其中,所述调用请求中携带所述剩余响应时长,所述第一响应数据为:所述当前服务节点在所述剩余响应时长内反馈至所述服务的响应数据。
可选的,所述数据发送模块,具体用于:
判断所获得的响应数据是否为空;
若所获得的响应数据为空,将预设数据确定为待发送数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
第四方面,本发明实施例还提供了一种数据访问装置,应用于客户端,所述装置包括:
请求发送模块,用于向服务器发送数据访问请求,其中,所述数据访问请求携带预设响应时长;
目标响应数据接收模块,用于接收所述服务器发送的目标响应数据,其中,所述目标响应数据为:服务器在获得各个目标服务节点所提供响应数据的时长达到所述预设响应时长时,向所述客户端发送的响应数据,所述服务器向所述客户端发送的响应数据为:所述服务器根据各个目标服务节点提供的、用于响应所述数据访问请求的响应数据确定的数据,所述目标服务节点为:用于响应所述数据访问请求的服务节点;
目标响应数据展示模块,用于展示所接收的目标响应数据。
可选的,在各个目标服务节点提供的、用于响应所述数据访问请求的响应数据为空的情况下,所述服务器向所述客户端发送的响应数据为预设数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
第五方面,本发明实施例还提供了一种服务器,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现上述任一所述的数据访问方法。
第六方面,本发明实施例还提供了一种客户端,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现上述任一所述的数据访问方法。
在本发明实施的又一方面,还提供了一种计算机可读存储介质,所述计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行上述任一所述的数据访问方法。
在本发明实施的又一方面,本发明实施例还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行上述任一所述的数据访问方法。
与现有技术相比,本发明实施例提供的技术方案,客户端向服务器发送的数据访问请求携带预设响应时长;服务器在接收到该客户端发送的数据访问请求后,确定用户响应数据访问请求的目标服务节点,并调用各个目标服务节点来查找用于响应数据访问请求的响应数据;在各个目标服务节点查找到用于响应数据访问请求的响应数据之后,将查找到的响应数据发送至服务器;在获得各个目标服务节点所提供响应数据消耗的时间达到预设响应时长时,服务器将其从各个目标服务节点获得到响应数据发送至客户端,以供客户端展示服务器发送的响应数据,从而使得用户能够访问网络数据。
可见,通过本发明实施例提供的技术方案,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍。
图1为本发明实施例所提供的一种应用于服务器的数据访问方法的流程图;
图2为本发明实施例所提供的响应数据获取方法的流程图;
图3为本发明实施例所提供的一种数据访问方法的一种应用实例示意图;
图4为本发明实施例所提供的一种应用于客户端的数据访问方法的流程图;
图5为本发明实施例所提供的一种应用于服务器的数据访问装置的结构示意图;
图6为本发明实施例所提供的一种响应数据获取模块的结构示意图;
图7为本发明实施例所提供的一种应用于客户端的数据访问装置的结构示意图;
图8为本发明实施例所提供的一种服务器的结构示意图;
图9为本发明实施例所提供的一种客户端的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行描述。
为了解决现有技术问题,本发明实施例提供了一种数据访问方法、装置服务器及客户端,以使得用户能够访问其自身想要访问的数据,从而提高用户的体验。
第一方面,下面将对本发明实施例所提供的一种应用于服务器的数据访问方法进行介绍。
如图1所示,本发明实施例提供了一种数据访问方法,应用于服务器,所述方法包括:
S110,接收客户端发送的数据访问请求,其中,数据访问请求携带预设响应时长;
S120,确定用于响应数据访问请求的服务节点,作为目标服务节点;
S130,通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应数据访问请求的响应数据;
S140,在获得各个目标服务节点所提供响应数据消耗的时长达到所述预设响应时长时,根据所获得的响应数据确定待发送数据,将待发送数据发送至所述客户端,以使得客户端展示待发送数据。
可见,本发明实施例提供的技术方案中,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
下面将对如图1所示的实施例提供的数据访问方法进行详细描述。
S110,接收客户端发送的数据访问请求,其中,数据访问请求携带预设响应时长;
用户需要访问网络数据时,一般通过客户端向服务器发送数据访问请求,从而服务器接收到数据访问请求。可以理解的是,网络数据可以为:视频、图像、文字等等,本发明实施例对网络数据的种类不做具体限定。
在该步骤中,数据访问请求中携带有预设响应时长,该预设响应时长可以是客户端预先设定的,也就是说,客户端期望在该预设响应时长内获得用于响应数据访问请求的响应数据。客户端通过将携带预设响应时长的数据访问请求发送至服务器,使得服务器能够得知客户端期望在该预设响应时长内获得用于响应数据访问请求的响应数据,以便服务器能够在该预设响应时长内向客户端发送用于响应数据访问请求的响应数据。
可以理解的是,客户端可以根据其实际情况来设置上述预设响应时长,也就是说,上述预设响应时长的大小可大可小。例如,上述预设响应时长可以为5秒,10秒,15秒等等。本发明实施例对上述预设响应时长的大小不做具体限定。
S120,确定用于响应数据访问请求的服务节点,作为目标服务节点;
一种实现方式中,服务器在接收到客户端发送的数据访问请求后,根据数据访问请求确定出用户需要访问的网络数据的类型等信息,而用于提供各种类型的网络数据的服务节点往往是预先定义好的,进而服务器可以确定出用于响应上述数据访问请求的服务节点,也就是目标服务节点。
举例而言,服务器当前接收到三个数据访问请求,分别为数据访问请求1、数据访问请求2、数据访问请求3;
响应数据访问请求1和数据访问请求2的服务节点相同,均为服务节点A、服务节点B、服务节点C这三个服务节点;而响应数据访问请求3的服务节点为服务节点A、服务节点B、服务节点C、服务节点D、服务节点E。
那么,对于数据访问请求1和数据访问请求2而言,服务器确定的目标服务节点均为:服务节点A、服务节点B、服务节点C;
对于数据访问请求3而言,服务器确定的目标服务节点为:服务节点A、服务节点B、服务节点C、服务节点D、服务节点E。
可以理解的是,用于响应数据访问请求的目标服务节点可以是执行主体服务器中的服务节点,也可以是其他服务器中的服务节点,这都是合理的。
S130,通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应数据访问请求的响应数据;
服务器确定了用于响应数据访问请求的目标服务节点后,调用各个目标服务节点,各个目标服务节点查找用于响应数据访问请求的响应数据,并将查找到的响应数据发送至服务器,从而服务器获得各个目标服务节点提供的、用于响应数据访问请求的响应数据。
需要强调的是,为了方案描述清楚,将在下面图2所示的实施例中详细阐述“通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应数据访问请求的响应数据”的具体实现方式。
S140,在获得各个目标服务节点所提供响应数据消耗的时长达到预设响应时长时,根据所获得的响应数据确定待发送数据,将待发送数据发送至所述客户端,以使得客户端展示待发送数据。
具体的,服务器获得各个目标服务节点提供的响应数据所消耗的时间可能小于预设响应时长,也可能大于等于预设响应时长。
当服务器获得各个目标服务节点提供的响应数据所消耗的时间小于预设响应时长时,服务器可以在预设响应时长内获得各个目标服务节点提供的全部响应数据,然后将各个目标服务节点提供的全部响应数据发送至客户端,以供客户端展示接收到的全部响应数据。
当服务器获得各个目标服务节点提供的响应数据所消耗的时间大于等于预设响应时长时,服务器不能在预设响应时长内获得各个目标服务节点提供的全部响应数据。此时,为了使得客户端能够获得用于响应数据访问请求的响应数据,在获得各个目标服务节点所提供的响应数据消耗的时间达到预设响应时长时,服务器将预设响应时长内各个目标服务节点向其提供的响应数据发送至客户端,以供客户端展示接收到的全部响应数据。
例如,预设响应时长为15秒,响应数据访问请求的目标服务节点为服务节点A、服务节点B、服务节点C,假设服务器调用服务节点的顺序为:服务节点A、服务节点B、服务节点C。
首先,服务器首先调用服务节点A,服务节点A消耗了3秒的时间为服务器反馈了用于响应数据访问请求的响应数据,可见,服务器从服务节点A获得用于响应数据访问请求的响应数据所消耗的时间小于预设响应时长(3秒小于15秒),且可以计算出剩余响应时长为12(15-3)秒;
其次,服务器调用服务节点B,服务节点B消耗了5秒的时间为服务器反馈了用于响应数据访问请求的响应数据,可见,服务器从服务节点B获得用于响应数据访问请求的响应数据所消耗的时间小于剩余响应时长(5秒小于12秒);且可以计算出当前剩余响应时长为7(12-5)秒;
接下来,服务器调用服务节点C,服务节点C消耗了3秒的时间为服务器反馈了用于响应数据访问请求的响应数据,可见,服务器从服务节点B获得用于响应数据访问请求的响应数据所消耗的时间小于当前剩余响应时长(3秒小于7秒);
综上所述,服务器获得各个目标服务节点提供的全部响应数据所消耗的时间为:5+3+5=13秒(小于15秒),服务器在获得目标服务节点A、目标服务节点B、目标服务节点C提供的用于响应数据访问请求的全部响应数据后,即将所获得的全部响应数据发送至客户端,以供客户端展示其所接收到的全部响应数据。
再例如,预设响应时长为15秒,响应数据访问请求的目标服务节点为服务节点A、服务节点B、服务节点C,假设服务器调用服务节点的顺序为:服务节点A、服务节点B、服务节点C。
首先,服务器首先调用服务节点A,服务节点A消耗了5秒的时间为服务器反馈了用于响应数据访问请求的响应数据,可见,服务器从服务节点A获得用于响应数据访问请求的响应数据所消耗的时间小于预设响应时长(5秒小于15秒),且可以计算出剩余响应时长为10(15-5)秒;
其次,服务器调用服务节点B,服务节点B消耗了6秒的时间为服务器反馈了用于响应数据访问请求的响应数据,可见,服务器从服务节点B获得用于响应数据访问请求的响应数据所消耗的时间小于剩余响应时长(6秒小于10秒);且可以计算出当前剩余响应时长为4(10-6)秒;
接下来,服务器调用服务节点C,服务器在剩余响应时长为0时,还未获取到服务节点C为其提供的用于响应数据访问请求的响应数据。
由上述描述可知:服务器获得各个目标服务节点提供的响应数据所消耗的时间将会大于预设响应时长(15秒)。这种情况下,在获得各个目标服务节点所提供响应数据消耗的时间达到15秒时,服务器只将从目标服务节点A、目标服务节点B获得用于响应数据访问请求的响应数据发送至客户端,从而客户端可以展示其从目标服务节点A和目标服务节点B获得的响应数据。
与现有技术相比,本发明实施例提供的技术方案,客户端向服务器发送的数据访问请求携带预设响应时长;服务器在接收到该客户端发送的数据访问请求后,确定用户响应数据访问请求的目标服务节点,并调用各个目标服务节点来查找用于响应数据访问请求的响应数据;在各个目标服务节点查找到用于响应数据访问请求的响应数据之后,将查找到的响应数据发送至服务器;在获得各个目标服务节点所提供响应数据消耗的时间达到预设响应时长时,服务器将其从各个目标服务节点获得到响应数据发送至客户端,以供客户端展示服务器发送的响应数据,从而使得用户能够访问网络数据。
可见,通过本发明实施例提供的技术方案,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
下面将详细阐述“通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应数据访问请求的响应数据”的一种具体实现方式。
如图2所示,S130通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应所述数据访问请求的响应数据,可以包括如下步骤:
S131,设置当前服务节点为第一服务节点,并将预设响应时长确定为剩余响应时长,其中,第一服务节点为:目标服务节点中调用优先级最高的服务节点,调用优先级为:根据数据访问请求确定的调用各个目标服务节点的优先级;
服务器在确定了响应数据访问请求的目标服务节点后,服务器按照一定的调用顺序来调用各个目标服务节点,该调用顺序由数据访问请求确定,其中,最先调用的目标服务节点的优先级最高,最后调用的目标服务节点的优先级最低。也就是说,上述调用顺序是按照目标服务节点被调用的优先级确定的,同一优先级可以对应于一个目标服务节点,也可以对应于一个以上目标服务节点。基于此,上述第一服务节点可能仅仅是一个目标服务节点,还有可能是一个以上目标服务节点,进而上述当前服务节点可能仅仅是一个目标服务节点,还有可能是一个以上目标服务节点。
例如,响应数据访问请求的目标服务节点为:服务节点A、服务节点B、服务节点C,响应该数据访问请求需要首先调用服务节点A,其次调用服务节点B,最后调用服务节点C。
那么,这三个目标服务节点中,服务节点A的优先级最高,服务节点B的优先级居中,服务节点C的优先级最低。这种情况下,第一服务节点为服务节点A,即服务节点A为当前服务节点,服务器首先调用服务节点A,然后调用服务节点B,最后调用服务节点C。
再例如,响应数据访问请求的目标服务节点为:服务节点A、服务节点B、服务节点C,响应该数据访问请求首先需要调用服务节点A和服务节点B,然后调用服务节点C,那么三个目标服务节点中,服务节点A和服务节点B的优先级最高,服务节点C的优先级最低。
这种情况下,第一服务节点为服务节点A和服务节点B,即服务节点A和服务节点B为当前服务节点,服务器首先调用服务节点A和服务节点B,然后调用服务节点C。
S132,通过调用当前服务节点,获得第一响应数据,其中,第一响应数据为:当前服务节点提供的、用于响应数据访问请求的响应数据;
由步骤S131的描述可知,当前服务节点可以是一个服务节点,也可以是多个服务节点。
若当前服务节点是一个服务节点时,服务器调用该当前服务节点,该当前服务节点查找用于响应数据访问请求的响应数据,可以理解的是,当前服务节点查找到的响应数据为第一响应数据;当前服务节点将第一响应数据发送至服务器,从而服务器能够获得第一响应数据。
若当前服务节点为多个服务节点,那么服务器可以同步调用这多个服务节点,这多个服务节点分别查找用于响应数据访问请求的响应数据,这多个服务节点中每一服务节点查找到用于响应数据访问请求的响应数据后,会将其查找到的数据发送至服务器,在服务器获得了这多个服务节点返回的响应数据后,本步骤执行完成。
举例而言,以步骤S131中所举的第一个例子为例,由于当前服务节点为服务节点A,那么,服务器通过调用服务节点A,获得第一响应数据,该第一响应数据为服务节点A提供的用于响应数据访问请求的响应数据。
以步骤S131中所举的第二个例子为例,由于当前服务节点为服务节点A和服务节点B,那么,服务器通过调用服务节点A和服务节点B,获得第一响应数据,该第一响应数据为服务节点A和服务节点B提供的用于响应数据访问请求的响应数据。
需要说明的是,通过调用当前服务节点获得第一响应数据可以有多种实现方式。
在一种实现方式中,通过调用当前服务节点,获得第一响应数据,可以包括:
通过向当前服务节点发送调用请求的方式调用当前服务节点,获得第一响应数据,其中,调用请求中携带所述剩余响应时长,第一响应数据为:当前服务节点在剩余响应时长内反馈至服务器的响应数据。
在该实施方式中,服务器调用当前服务节点时,向当前服务节点发送调用请求,且调用请求中携带有剩余响应时长,这样当前服务节点能够监控其查找用于响应数据访问请求的响应数据所消耗的时间是否超过剩余响应时长,这样,若当前服务节点在剩余响应时长内没有查找到用于响应数据访问请求的响应数据,当前服务节点会主动向服务器反馈查找响应超时的信息。
举例而言,预设响应时长为15秒,响应数据访问请求的目标服务节点为服务节点A、服务节点B、服务节点C,服务器调用各个目标服务节点的顺序为:服务节点A、服务节点B、服务节点C。
首先,服务器向服务节点A发送第一调用请求,其中,该第一调用请求中携带的剩余响应时长为15秒,服务节点A消耗了5秒的时间为服务器反馈了用于响应数据访问请求的响应数据,此时,更新后的剩余响应时长为10秒;
其次,服务器向服务节点B发送第二调用请求,其中,该第二调用请求中携带的剩余响应时长为10秒,服务节点B消耗了3秒的时间为服务器反馈了用于响应数据访问请求的响应数据,此时,更新后的剩余响应时长为7秒;
最后,服务器向服务节点C发送第三调用请求,其中,该第三调用请求中携带的剩余响应时长为7秒,服务节点C消耗了5秒的时间为服务器反馈了用于响应数据访问请求的响应数据,此时,更新后的剩余响应时长为2秒;
由上述描述可知,服务器调用各个目标服务节点之后,更新后的剩余响应时长仍大于0,说明服务器通过调用各个目标服务节点获得了用于响应数据访问请求的全部响应数据。
当然,在另一种实现方式中,服务器也可以通过发送调用请求的方式来调用当前服务节点,但是,该调用请求中不携带剩余响应时长,这种情况下,执行主体服务器本身可以监控当前服务节点查找用于响应数据访问请求的响应数据所消耗的时间是否超过剩余响应时长,如果当前服务节点查找用于响应数据访问请求的响应数据所消耗的时间超过剩余响应时长,则将当前已经获得的用于响应数据访问请求的响应数据发送到客户端。
S133,利用获得第一响应数据所消耗的时长,更新剩余响应时长;
由于通过当前服务节点获得第一响应数据需要消耗时间,由步骤S131可知:剩余响应时长的初始值为预设响应时长,利用剩余响应时长的初始值减去获得第一响应数据所消耗的时长,即可获得当前剩余响应时长,从而达到更新剩余响应时长的目的。
S134,若剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将当前服务节点更新为第二服务节点,并返回执行步骤S220,其中,第二服务节点为:调用优先级为目标调用优先级的目标服务节点,目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级。
如果剩余响应时长大于0,说明在调用第一服务节点获得第一响应数据所消耗的时间小于预设响应时长,此时,服务器还可以调用第二服务节点,其中,该第二服务节点的调用优先级为第一服务节点调用优先级的下一调用优先级。
举例而言,仍以步骤S131中所举的第一个例子为例,响应数据访问请求的目标节点为:服务节点A、服务节点B、服务节点C。由于服务节点A的优先级最高,服务节点B的优先级居中,服务节点C的优先级最低,即服务节点A为第一服务节点,服务节点B为第二服务节点。
服务器通过调用第二服务节点来获取用户响应数据访问请求的响应数据后,再次更新剩余响应时长,如果剩余响应时长大于0,则再调用下一个当前服务节点,其中,下一个当前服务节点的调用优先级为第二服务节点的调用优先级下一级的调用优先级。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器每次调用当前服务节点获得用于响应数据访问请求的响应数据后,均会更新剩余响应时间,若更新后的剩余响应时间大于0,则继续调用下一服务节点,在剩余响应时间为0时,服务器将从各个目标服务节点获取到的用于响应数据访问请求的响应数据发送至客户端。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
需要强调的是,在上述实施例中,如果服务器获得各个目标服务节点所提供响应数据消耗的时间达到预设响应时长时,服务器没有从各个目标服务节点中获取到用于响应数据访问请求的响应数据,也就是说,服务器从各个目标服务节点中获取到的用于响应数据访问请求的响应数据为空时,服务器将预设数据发送至客户端。例如,该预设数据可以为:“稍后重试”、“请刷新”、“获取数据超时”等等。可以理解的是,能够用于提示用户客户端未能获取到响应数据的数据均可以为本发明实施例中的预设数据,本发明实施例对预设数据并不做具体限定。
举例而言,预设响应时长为15秒,响应数据访问请求的目标服务节点为服务节点A、服务节点B、服务节点C,服务器调用各个目标服务节点的顺序为:服务节点A、服务节点B、服务节点C。
如果服务节点A在剩余响应时长为0时,没有向服务器获得用于响应数据访问请求的响应数据,说明服务节点A查找用于响应数据访问请求的响应数据所消耗的时间超过预设响应时长(15秒),此时,服务器向客户端发送预设数据,以提示用户客户端未能获取到用于响应数据访问请求的响应数据。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将各个目标节点向其反馈的数据发送至客户端;如果各个目标节点向其反馈的数据为用于响应数据访问请求的响应数据,则客户端展示响应数据;如果各个目标节点向其反馈的数据为预设数据,则客户端展示预设数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
为了更加清楚地描述本发明实施例的技术方案,下面结合具体的实施例,对本发明实施例所提供的一种数据访问方法进行介绍,如图3所示:
1、用户需要访问网络数据时,通过客户端向服务器数据访问请求,该数据访问请求携带的预设响应时长为10秒;
2、服务器接收到该数据访问请求后,确定响应该数据访问请求的目标服务节点,目标服务节点为:服务节点A、服务节点B、服务节点C,且服务节点A的调用优先级最高,服务节点B的调用优先级居中,服务节点C的调用优先级最低;
3、服务器向服务节点A发送第一调用请求以调用优先级最高的服务节点A,该第一调用请求携带的当前剩余响应时长为预设响应时长,即为10秒。服务节点A接收到第一调用请求后,查找用于响应数据访问请求的响应数据,并将查找到的响应数据反馈给服务器,其中,服务器获得服务节点A向其反馈的响应数据所消耗的时间为3秒;
4、服务器更新剩余响应时长,此时的剩余响应时长为7秒;
5、服务器向服务节点B发送第二调用请求以调用优先级最高的服务节点B,该第二调用请求携带的当前剩余响应时长为更新后的剩余响应时长,即为7秒。服务节点B接收到第二调用请求后,查找用于响应数据访问请求的响应数据,并将查找到的响应数据反馈给服务器,其中,服务器获得服务节点B向其反馈的响应数据共耗时5秒;
5、服务器第二次更新剩余响应时长,此时的剩余响应时长为2秒;
6、服务器向服务节点B发送第三调用请求以调用优先级最高的服务节点C,该第三调用请求携带的当前剩余响应时长为第二次更新后的剩余响应时长,即为2秒。服务节点C接收到第三调用请求后,查找用于响应数据访问请求的响应数据,在剩余响应时长为0时,在服务节点C向服务器反馈的数据为:“响应时间超时“,即说明服务节点C查找用于响应数据访问请求的响应数据所消耗的时间大于第二次更新后的剩余响应时长。
7、在服务器获得服务节点A、服务节点B、服务节点C所提供响应数据消耗的时间达到预设响应时长10秒时,服务器将从服务节点A和服务节点B获得的用于响应数据访问请求的响应数据发送至客户端;
8、客户端展示从服务节点A和服务节点B获得的用于响应数据访问请求的响应数据。
第二方面,本发明实施例还提供了一种应用于客户端的数据访问方法,如图4所示,所述方法包括:
S410,向服务器发送数据访问请求,其中,数据访问请求携带预设响应时长;
用户需要访问网络数据时,一般通过客户端向服务器发送数据访问请求,从而服务器接收到数据访问请求。可以理解的是,网络数据可以为:视频、图像、文字等等,举例而言,用户想要查看某视频,则通过客户端向服务器发送视频访问请求。
在该步骤中,数据访问请求中携带有预设响应时长,该预设响应时长可以是客户端预先设定的,也就是说,客户端期望在该预设响应时长内获得用于响应数据访问请求的响应数据。客户端通过将携带预设响应时长的数据访问请求发送至服务器,使得服务器能够得知客户端期望在该预设响应时长内获得用于响应数据访问请求的响应数据,以便服务器能够在该预设响应时长内向客户端发送用于响应数据访问请求的响应数据。
S420,接收服务器发送的目标响应数据,其中,目标响应数据为:服务器在获得各个目标服务节点所提供响应数据的时长达到所述预设响应时长时,向客户端发送的响应数据,服务器向客户端发送的响应数据为:服务器根据各个目标服务节点提供的、用于响应数据访问请求的响应数据确定的数据,目标服务节点为:用于响应数据访问请求的服务节点;
服务器获得各个目标服务节点所提供的目标响应数据后,向客户端发送目标响应数据。
需要说明的是,如果在预设响应时长内,各个目标服务节点能够向服务器反馈用于响应数据访问请求的响应数据,则目标响应数据为各个目标服务节点提供的用于响应数据访问请求的响应数据;如果在预设响应时长内,各个目标服务节点没有向服务器反馈用于响应数据访问请求的响应数据,则目标响应数据为预设数据,该预设数据用于提示用户客户端未能获取到用于响应数据访问请求的响应数据。
S430,展示所接收的目标响应数据。
当目标响应数据为用于响应数据访问请求的响应数据,则客户端将用于响应数据访问请求的响应数据展示出来,以供用户访问其自身需要访问的网络数据。
当目标响应数据为预设数据,则客户端将预设数据展示出来,以提示用户客户端未能获取到用于响应数据访问请求的响应数据。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
第三方面,本发明实施例还提供了一种应用于服务器的数据访问装置,如图5所示,所述装置包括:
请求接收模块510,用于接收客户端发送的数据访问请求,其中,所述数据访问请求携带预设响应时长;
服务节点确定模块520,用于确定用于响应所述数据访问请求的服务节点,作为目标服务节点;
响应数据获取模块530,用于通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应所述数据访问请求的响应数据;
数据发送模块540,用于在获得各个目标服务节点所提供响应数据消耗的时长达到所述预设响应时长时,根据所获得的响应数据确定待发送数据,将所述待发送数据发送至所述客户端,以使得所述客户端展示所述待发送数据。
与现有技术相比,本发明实施例提供的技术方案,客户端向服务器发送的数据访问请求携带预设响应时长;服务器在接收到该客户端发送的数据访问请求后,确定用户响应数据访问请求的目标服务节点,并调用各个目标服务节点来查找用于响应数据访问请求的响应数据;在各个目标服务节点查找到用于响应数据访问请求的响应数据之后,将查找到的响应数据发送至服务器;在获得各个目标服务节点所提供响应数据消耗的时间达到预设响应时长时,服务器将其从各个目标服务节点获得到响应数据发送至客户端,以供客户端展示服务器发送的响应数据,从而使得用户能够访问网络数据。
可见,通过本发明实施例提供的技术方案,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
在一种实施方式中,如图6所示,响应数据获取模块530,可以包括:
信息确定单元531,用于设置当前服务节点为第一服务节点,并将所述预设响应时长确定为剩余响应时长,其中,所述第一服务节点为:目标服务节点中调用优先级最高的服务节点,所述调用优先级为:根据所述数据访问请求确定的调用各个目标服务节点的优先级;
第一响应数据获取单元532,用于通过调用所述当前服务节点,获得第一响应数据,其中,所述第一响应数据为:所述当前服务节点提供的、用于响应所述数据访问请求的响应数据;
剩余响应时长更新模块533,用于利用获得所述第一响应数据所消耗的时长,更新所述剩余响应时长;
当前服务节点更新单元534,用于若所述剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将所述当前服务节点更新为第二服务节点,并返回执行所述通过调用所述当前服务节点,获得所述当前服务节点提供的、用于响应所述数据访问请求的响应数据的步骤,所述第二服务节点为:调用优先级为目标调用优先级的目标服务节点,所述目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级。
可选的,所述第一响应数据获取单元532,具体用于:
通过向所述当前服务节点发送调用请求的方式调用所述当前服务节点,获得第一响应数据,其中,所述调用请求中携带所述剩余响应时长,所述第一响应数据为:所述当前服务节点在所述剩余响应时长内反馈至所述服务的响应数据。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器每次调用当前服务节点获得用于响应数据访问请求的响应数据后,均会更新剩余响应时间,若更新后的剩余响应时间大于0,则继续调用下一服务节点,在剩余响应时间为0时,服务器将从各个目标服务节点获取到的用于响应数据访问请求的响应数据发送至客户端。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
可选的,所述数据发送模块,具体用于:
判断所获得的响应数据是否为空;
若所获得的响应数据为空,将预设数据确定为待发送数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将各个目标节点向其反馈的数据发送至客户端;如果各个目标节点向其反馈的数据为用于响应数据访问请求的响应数据,则客户端展示响应数据;如果各个目标节点向其反馈的数据为预设数据,则客户端展示预设数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
第四方面,本发明实施例还提供了一种应用于客户端的数据访问装置,如图7所示,所述装置包括:
请求发送模块710,用于向服务器发送数据访问请求,其中,所述数据访问请求携带预设响应时长;
目标响应数据接收模块720,用于接收所述服务器发送的目标响应数据,其中,所述目标响应数据为:服务器在获得各个目标服务节点所提供响应数据的时长达到所述预设响应时长时,向所述客户端发送的响应数据,所述服务器向所述客户端发送的响应数据为:所述服务器根据各个目标服务节点提供的、用于响应所述数据访问请求的响应数据确定的数据,所述目标服务节点为:用于响应所述数据访问请求的服务节点;
目标响应数据展示模块730,用于展示所接收的目标响应数据。
可选的,在各个目标服务节点提供的、用于响应所述数据访问请求的响应数据为空的情况下,所述服务器向所述客户端发送的响应数据为预设数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
第五方面,本发明实施例还提供了一种服务器,如图8所示,包括处理器801、通信接口802、存储器803和通信总线804,其中,处理器801,通信接口802,存储器803通过通信总线804完成相互间的通信,
存储器803,用于存放计算机程序;
处理器801,用于执行存储器803上所存放的程序时,实现第一方面方法实施例所述的任一数据访问方法。
上述电子设备提到的通信总线可以是外设部件互连标准(Peripheral PomponentInterconnect,简称PCI)总线或扩展工业标准结构(Extended Industry StandardArchitecture,简称EISA)总线等。该通信总线可以分为地址总线、数据总线、控制总线等。为便于表示,图中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
通信接口用于上述电子设备与其他设备之间的通信。
存储器可以包括随机存取存储器(Random Access Memory,简称RAM),也可以包括非易失性存储器(non-volatile memory),例如至少一个磁盘存储器。可选的,存储器还可以是至少一个位于远离前述处理器的存储装置。
上述的处理器可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Ne twork Processor,简称NP)等;还可以是数字信号处理器(Digital Signal Processing,简称DSP)、专用集成电路(Applica tion SpecificIntegrated Circuit,简称ASIC)、现场可编程门阵列(Field-Programmable Gate Array,简称FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。
与现有技术相比,通过本发明实施例提供的技术方案,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
第六方面,本发明实施例还提供了一种客户端,如图9所示,包括处理器901、通信接口902、存储器903和通信总线904,其中,处理器901,通信接口902,存储器903通过通信总线904完成相互间的通信,
存储器903,用于存放计算机程序;
处理器901,用于执行存储器903上所存放的程序时,实现第二方面方法实施例所述的任一数据访问方法。
上述电子设备提到的通信总线可以是外设部件互连标准(Peripheral PomponentInterconnect,简称PCI)总线或扩展工业标准结构(Extended Industry StandardArchitecture,简称EISA)总线等。该通信总线可以分为地址总线、数据总线、控制总线等。为便于表示,图中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
通信接口用于上述电子设备与其他设备之间的通信。
存储器可以包括随机存取存储器(Random Access Memory,简称RAM),也可以包括非易失性存储器(non-volatile memory),例如至少一个磁盘存储器。可选的,存储器还可以是至少一个位于远离前述处理器的存储装置。
上述的处理器可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Ne twork Processor,简称NP)等;还可以是数字信号处理器(Digital Signal Processing,简称DSP)、专用集成电路(Applica tion SpecificIntegrated Circuit,简称ASIC)、现场可编程门阵列(Field-Programmable Gate Array,简称FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
在本发明提供的又一实施例中,还提供了一种计算机可读存储介质,该计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行第一方面方法实施例中所述的任一数据访问方法。
与现有技术相比,通过本发明实施例提供的技术方案,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
在本发明提供的又一实施例中,还提供了一种计算机可读存储介质,该计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行第二方面方法实施例中所述的任一数据访问方法。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
在本发明提供的又一实施例中,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行第一方面方法实施例中所述的任一数据访问方法。
与现有技术相比,通过本发明实施例提供的技术方案,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
在本发明提供的又一实施例中,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行第二方面方法实施例中所述的任一数据访问方法。
与现有技术相比,由于服务端接收到的数据访问请求中携带有预设响应时长,服务器在获得各个目标服务节点所提供响应数据消耗的时间达到该预设响应时长时,即可以将用于响应数据访问请求的响应数据发送至客户端;而不像现有技术那样,如果客户端在其期望的时长内没有获得用于响应数据访问请求的响应数据,则主动放弃从服务器获得上述数据访问请求的响应数据。因此,通过本发明实施例提供的技术方案,可以使得用户能够访问其自身想要访问的数据,从而提高了用户的体验。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。所述计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行所述计算机程序指令时,全部或部分地产生按照本发明实施例所述的流程或功能。所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一个计算机可读存储介质传输,例如,所述计算机指令可以从一个网站站点、计算机、服务器或数据中心通过有线(例如同轴电缆、光纤、数字用户线(DSL))或无线(例如红外、无线、微波等)方式向另一个网站站点、计算机、服务器或数据中心进行传输。所述计算机可读存储介质可以是计算机能够存取的任何可用介质或者是包含一个或多个可用介质集成的服务器、数据中心等数据存储设备。所述可用介质可以是磁性介质,(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质(例如固态硬盘Solid State Disk(SSD))等。
需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
本说明书中的各个实施例均采用相关的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于装置、服务器、终端、存储介质、计算机程序产品实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所作的任何修改、等同替换、改进等,均包含在本发明的保护范围内。

Claims (12)

1.一种数据访问方法,其特征在于,应用于服务器,所述方法包括:
接收客户端发送的数据访问请求,其中,所述数据访问请求携带预设响应时长;
确定用于响应所述数据访问请求的服务节点,作为目标服务节点;
通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应所述数据访问请求的响应数据;
在获得各个目标服务节点所提供响应数据消耗的总时长达到所述预设响应时长时,根据所获得的响应数据确定待发送数据,将所述待发送数据发送至所述客户端,以使得所述客户端展示所述待发送数据;
所述通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应所述数据访问请求的响应数据,包括:
设置当前服务节点为第一服务节点,并将所述预设响应时长确定为剩余响应时长,其中,所述第一服务节点为:目标服务节点中调用优先级最高的服务节点,所述调用优先级为:根据所述数据访问请求确定的调用各个目标服务节点的优先级;
通过调用所述当前服务节点,获得第一响应数据,其中,所述第一响应数据为:所述当前服务节点提供的、用于响应所述数据访问请求的响应数据;
利用获得所述第一响应数据所消耗的时长,更新所述剩余响应时长;
若所述剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将所述当前服务节点更新为第二服务节点,并返回执行所述通过调用所述当前服务节点,获得第一响应数据的步骤,所述第二服务节点为:调用优先级为目标调用优先级的目标服务节点,所述目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级。
2.根据权利要求1所述的方法,其特征在于,所述通过调用所述当前服务节点,获得第一响应数据,包括:
通过向所述当前服务节点发送调用请求的方式调用所述当前服务节点,获得第一响应数据,其中,所述调用请求中携带所述剩余响应时长,所述第一响应数据为:所述当前服务节点在所述剩余响应时长内反馈至所述服务器的响应数据。
3.根据权利要求1-2中任一项所述的方法,其特征在于,所述根据所获得的响应数据确定待发送数据,包括:
判断所获得的响应数据是否为空;
若所获得的响应数据为空,将预设数据确定为待发送数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
4.一种数据访问方法,其特征在于,应用于客户端,所述方法包括:
向服务器发送数据访问请求,其中,所述数据访问请求携带预设响应时长;
接收所述服务器发送的目标响应数据,其中,所述目标响应数据为:服务器在获得各个目标服务节点所提供响应数据的总时长达到所述预设响应时长时,向所述客户端发送的响应数据,所述服务器向所述客户端发送的响应数据为:所述服务器根据各个目标服务节点提供的、用于响应所述数据访问请求的响应数据确定的数据,所述目标服务节点为:用于响应所述数据访问请求的服务节点;所述服务器通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应所述数据访问请求的响应数据,包括:设置当前服务节点为第一服务节点,并将所述预设响应时长确定为剩余响应时长,其中,所述第一服务节点为:目标服务节点中调用优先级最高的服务节点,所述调用优先级为:根据所述数据访问请求确定的调用各个目标服务节点的优先级;通过调用所述当前服务节点,获得第一响应数据,其中,所述第一响应数据为:所述当前服务节点提供的、用于响应所述数据访问请求的响应数据;利用获得所述第一响应数据所消耗的时长,更新所述剩余响应时长;若所述剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将所述当前服务节点更新为第二服务节点,并返回执行所述通过调用所述当前服务节点,获得第一响应数据的步骤,所述第二服务节点为:调用优先级为目标调用优先级的目标服务节点,所述目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级;
展示所接收的目标响应数据。
5.根据权利要求4所述的方法,其特征在于,在各个目标服务节点提供的、用于响应所述数据访问请求的响应数据为空的情况下,所述服务器向所述客户端发送的响应数据为预设数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
6.一种数据访问装置,其特征在于,应用于服务器,所述装置包括:
请求接收模块,用于接收客户端发送的数据访问请求,其中,所述数据访问请求携带预设响应时长;
服务节点确定模块,用于确定用于响应所述数据访问请求的服务节点,作为目标服务节点;
响应数据获取模块,用于通过调用各个目标服务节点,获得各个目标服务节点提供的、且用于响应所述数据访问请求的响应数据;
数据发送模块,用于在获得各个目标服务节点所提供响应数据消耗的总时长达到所述预设响应时长时,根据所获得的响应数据确定待发送数据,将所述待发送数据发送至所述客户端,以使得所述客户端展示所述待发送数据;
所述响应数据获取模块,包括:
信息确定单元,用于设置当前服务节点为第一服务节点,并将所述预设响应时长确定为剩余响应时长,其中,所述第一服务节点为:目标服务节点中调用优先级最高的服务节点,所述调用优先级为:根据所述数据访问请求确定的调用各个目标服务节点的优先级;
第一响应数据获取单元,用于通过调用所述当前服务节点,获得第一响应数据,其中,所述第一响应数据为:所述当前服务节点提供的、用于响应所述数据访问请求的响应数据;
剩余响应时长更新模块,用于利用获得所述第一响应数据所消耗的时长,更新所述剩余响应时长;
当前服务节点更新单元,用于若所述剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将所述当前服务节点更新为第二服务节点,并返回执行所述通过调用所述当前服务节点,获得所述当前服务节点提供的、用于响应所述数据访问请求的响应数据的步骤,所述第二服务节点为:调用优先级为目标调用优先级的目标服务节点,所述目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级。
7.根据权利要求6所述的装置,其特征在于,所述第一响应数据获取单元,具体用于:
通过向所述当前服务节点发送调用请求的方式调用所述当前服务节点,获得第一响应数据,其中,所述调用请求中携带所述剩余响应时长,所述第一响应数据为:所述当前服务节点在所述剩余响应时长内反馈至所述服务的响应数据。
8.根据权利要求6-7中任一项所述的装置,其特征在于,所述数据发送模块,具体用于:
判断所获得的响应数据是否为空;
若所获得的响应数据为空,将预设数据确定为待发送数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
9.一种数据访问装置,其特征在于,应用于客户端,所述装置包括:
请求发送模块,用于向服务器发送数据访问请求,其中,所述数据访问请求携带预设响应时长;
目标响应数据接收模块,用于接收所述服务器发送的目标响应数据,其中,所述目标响应数据为:服务器在获得各个目标服务节点所提供响应数据的总时长达到所述预设响应时长时,向所述客户端发送的响应数据,所述服务器向所述客户端发送的响应数据为:所述服务器根据各个目标服务节点提供的、用于响应所述数据访问请求的响应数据确定的数据,所述目标服务节点为:用于响应所述数据访问请求的服务节点;所述服务器通过调用各个目标服务节点,获得各个目标服务节点提供的、用于响应所述数据访问请求的响应数据,包括:设置当前服务节点为第一服务节点,并将所述预设响应时长确定为剩余响应时长,其中,所述第一服务节点为:目标服务节点中调用优先级最高的服务节点,所述调用优先级为:根据所述数据访问请求确定的调用各个目标服务节点的优先级;通过调用所述当前服务节点,获得第一响应数据,其中,所述第一响应数据为:所述当前服务节点提供的、用于响应所述数据访问请求的响应数据;利用获得所述第一响应数据所消耗的时长,更新所述剩余响应时长;若所述剩余响应时长大于0、且未遍历目标服务节点中每一服务节点时,将所述当前服务节点更新为第二服务节点,并返回执行所述通过调用所述当前服务节点,获得第一响应数据的步骤,所述第二服务节点为:调用优先级为目标调用优先级的目标服务节点,所述目标调用优先级为:执行更新操作前当前服务节点调用优先级的下一调用优先级;
目标响应数据展示模块,用于展示所接收的目标响应数据。
10.根据权利要求9所述的装置,其特征在于,在各个目标服务节点提供的、用于响应所述数据访问请求的响应数据为空的情况下,所述服务器向所述客户端发送的响应数据为预设数据,其中,所述预设数据为:用于提示用户所述客户端未能获取到用于响应所述数据访问请求的响应数据。
11.一种服务器,其特征在于,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现权利要求1-3任一所述的方法步骤。
12.一种客户端,其特征在于,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现权利要求4或5所述的方法步骤。
CN201810008141.6A 2018-01-04 2018-01-04 一种数据访问方法、装置、服务器及客户端 Active CN108156252B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810008141.6A CN108156252B (zh) 2018-01-04 2018-01-04 一种数据访问方法、装置、服务器及客户端

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810008141.6A CN108156252B (zh) 2018-01-04 2018-01-04 一种数据访问方法、装置、服务器及客户端

Publications (2)

Publication Number Publication Date
CN108156252A CN108156252A (zh) 2018-06-12
CN108156252B true CN108156252B (zh) 2021-06-22

Family

ID=62460723

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810008141.6A Active CN108156252B (zh) 2018-01-04 2018-01-04 一种数据访问方法、装置、服务器及客户端

Country Status (1)

Country Link
CN (1) CN108156252B (zh)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109981779B (zh) * 2019-03-27 2022-02-22 掌阅科技股份有限公司 服务提供方法、服务器及计算机存储介质
CN109995787A (zh) * 2019-04-10 2019-07-09 北京奇艺世纪科技有限公司 一种数据处理方法及相关设备
CN110430101B (zh) * 2019-08-28 2021-09-03 杭州领智云画科技有限公司 应用于cdn的服务指标数据采集方法、装置、设备及系统
CN111159269B (zh) * 2019-12-30 2024-02-02 北京奇艺世纪科技有限公司 一种数据处理方法、装置及系统
CN111614747B (zh) * 2020-05-18 2023-03-10 北京奇艺世纪科技有限公司 一种信息处理方法及装置
CN113765979B (zh) * 2020-11-20 2022-12-02 北京沃东天骏信息技术有限公司 信息传输方法、系统和装置
CN114567483B (zh) * 2022-02-28 2024-03-29 天翼安全科技有限公司 一种数据传输的方法、装置及电子设备

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106095506A (zh) * 2016-06-14 2016-11-09 乐视控股(北京)有限公司 一种页面加载方法及装置

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN100507885C (zh) * 2007-09-04 2009-07-01 北京中星微电子有限公司 存储器访问的仲裁方法、系统和设备
CN103530317B (zh) * 2013-09-12 2017-07-07 杭州电子科技大学 云存储系统中一种能耗自适应的副本管理方法
CN104811466B (zh) * 2014-01-28 2018-06-01 青岛海尔电子有限公司 云媒体资源分配的方法及装置
CN106330664A (zh) * 2015-06-30 2017-01-11 深圳市星电商科技有限公司 一种信息交互处理方法、系统及终端

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106095506A (zh) * 2016-06-14 2016-11-09 乐视控股(北京)有限公司 一种页面加载方法及装置

Also Published As

Publication number Publication date
CN108156252A (zh) 2018-06-12

Similar Documents

Publication Publication Date Title
CN108156252B (zh) 一种数据访问方法、装置、服务器及客户端
US10652315B2 (en) Method, apparatus, and system for distributing information in graphic code
CN108647240B (zh) 一种统计访问量的方法、装置、电子设备及存储介质
CN110677684B (zh) 视频处理、视频访问方法及分布式存储、视频访问系统
CN110781015A (zh) 消息队列的分配方法、装置、设备及计算机可读存储介质
US10320744B2 (en) Systems, devices, and methods for dynamic allocation of domain name acquisition resources
CN111159269B (zh) 一种数据处理方法、装置及系统
CN110928887A (zh) 一种数据处理方法及装置
CN112653736B (zh) 一种并行回源方法、装置及电子设备
CN111125240B (zh) 一种分布式事务实现方法、装置、电子设备及存储介质
CN112437148B (zh) 业务请求的处理方法、装置、业务服务器及系统
CN110955460B (zh) 一种服务进程启动方法、装置、电子设备和存储介质
CN112838980A (zh) 一种消息处理方法、系统、装置、电子设备及存储介质
CN112596820A (zh) 一种资源加载方法、装置、设备以及存储介质
CN109525654B (zh) 一种数据获取、发送方法、装置、客户端及服务器
CN108390770B (zh) 一种信息生成方法、装置及服务器
CN109995855B (zh) 一种数据获取方法、装置及终端
CN111400327B (zh) 一种数据同步方法、装置、电子设备及存储介质
CN108804195B (zh) 一种页面显示方法、装置、服务器及客户端
CN112052101A (zh) 一种广播的处理方法、装置及计算机系统
CN111131497A (zh) 文件传输方法、装置、电子设备及存储介质
CN112256654A (zh) 一种文档共享方法及装置
CN111625742A (zh) 一种大屏系统的网络请求调度方法、装置、系统及介质
CN111638987A (zh) 数据处理方法、装置、电子设备及存储介质
CN115150030B (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
GR01 Patent grant
GR01 Patent grant