CN110661826A - 代理服务器端处理网络请求的方法和代理服务器 - Google Patents

代理服务器端处理网络请求的方法和代理服务器 Download PDF

Info

Publication number
CN110661826A
CN110661826A CN201810688252.6A CN201810688252A CN110661826A CN 110661826 A CN110661826 A CN 110661826A CN 201810688252 A CN201810688252 A CN 201810688252A CN 110661826 A CN110661826 A CN 110661826A
Authority
CN
China
Prior art keywords
client
data
logic
proxy server
processing
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.)
Granted
Application number
CN201810688252.6A
Other languages
English (en)
Other versions
CN110661826B (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 Jingdong Century Trading Co Ltd
Beijing Jingdong Shangke Information Technology Co Ltd
Original Assignee
Beijing Jingdong Century Trading Co Ltd
Beijing Jingdong Shangke Information 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 Jingdong Century Trading Co Ltd, Beijing Jingdong Shangke Information Technology Co Ltd filed Critical Beijing Jingdong Century Trading Co Ltd
Priority to CN201810688252.6A priority Critical patent/CN110661826B/zh
Publication of CN110661826A publication Critical patent/CN110661826A/zh
Application granted granted Critical
Publication of CN110661826B publication Critical patent/CN110661826B/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/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • 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/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • H04L67/5681Pre-fetching or pre-delivering data based on network characteristics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/12Applying verification of the received information
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/12Applying verification of the received information
    • H04L63/123Applying verification of the received information received data contents, e.g. message integrity

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Transfer Between Computers (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明公开了代理服务器端处理网络请求的方法和代理服务器,涉及计算机技术领域。该方法的一具体实施方式包括:接收客户端发出的网络请求;在确定未缓存所述网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对所述网络请求的响应数据和所述异步加载数据;利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据;根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈。该实施方式能够减轻后端服务器和客户端的流量压力与计算压力,提高网页响应速度。

Description

代理服务器端处理网络请求的方法和代理服务器
技术领域
本发明涉及计算机技术领域,尤其涉及代理服务器端处理网络请求的方法和代理服务器。
背景技术
在目前的客户端/服务器等软件系统架构中,一般在后端服务器采用架构功能优化、设置后端缓存等手段,在前端采用交互体验改善、用户个性化改善等手段来提高后端服务器的并发请求处理能力、加快网页响应速度。在某些设置代理服务器的软件系统中,代理服务器主要用于网络请求的转发以及后端资源的缓存。
在实现本发明的过程中,发明人发现现有技术至少存在以下问题:在处理网络请求时,由于后端服务器和客户端均需进行多种逻辑处理与逻辑验证,当面对突发的高流量或页面内容丰富逻辑复杂时,后端服务器的性能会严重下降,页面展示会产生较高延时。
发明内容
有鉴于此,本发明实施例提供代理服务器端处理网络请求的方法和代理服务器,可预先将通用的、可缓存的后端业务逻辑和客户端业务逻辑移植到代理服务器,处理网络请求时在代理服务器执行上述逻辑,从而减轻后端服务器和客户端的流量压力与计算压力,提高网页响应速度。
为实现上述目的,根据本发明的一个方面,提供了一种代理服务器端处理网络请求的方法。
本发明实施例的代理服务器端处理网络请求的方法包括:接收客户端发出的网络请求;在确定未缓存所述网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对所述网络请求的响应数据和所述异步加载数据;利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据;根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈。
可选地,所述后端业务逻辑包括:后端处理逻辑和后端校验逻辑,所述客户端业务逻辑包括:客户端处理逻辑和客户端校验逻辑;所述利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据,具体包括:针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据缓存;针对所述异步加载数据执行所述客户端处理逻辑,将执行结果与所述异步加载数据合并之后利用所述客户端校验逻辑进行校验,在校验通过时将数据缓存。
可选地,所述根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈,具体包括:将通过所述后端校验逻辑校验的数据和通过所述客户端校验逻辑校验的数据合并为反馈数据,将全部或部分反馈数据向客户端返回。
可选地,所述方法进一步包括:在数据未通过所述后端校验逻辑或所述客户端校验逻辑的校验时,重新从后端服务器获取针对所述网络请求的响应数据或客户端的异步加载数据;在重新获取次数或监测到的后端服务器性能指标符合预设的降级策略时,使用预先缓存的降级数据并对后端服务器进行心跳检测。
可选地,代理服务器软件为OpenResty,所述后端业务逻辑和所述客户端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑和所述客户端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑和所述客户端业务逻辑采用PHP脚本实现;所述缓存包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;所述客户端包括:个人计算机PC端或移动终端。
为实现上述目的,根据本发明的另一方面,提供了另一种代理服务器端处理网络请求的方法。
本发明实施例的代理服务器端处理网络请求的方法包括:接收客户端发出的网络请求;在确定未缓存所述网络请求的请求数据时,从后端服务器获取针对所述网络请求的响应数据;利用预先缓存的后端业务逻辑处理所述响应数据,根据处理结果和所述响应数据向客户端反馈。
可选地,所述后端业务逻辑包括:后端处理逻辑和后端校验逻辑;以及,所述利用预先缓存的后端业务逻辑处理所述响应数据,根据处理结果和所述响应数据向客户端反馈包括:针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据向客户端返回。
可选地,代理服务器软件为OpenResty,所述后端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑采用PHP脚本实现;所述缓存包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;所述客户端包括:个人计算机PC端、移动终端或内容分发网络CDN的边缘节点。
为实现上述目的,根据本发明的再一方面,提供了一种代理服务器。
本发明实施例的代理服务器可包括:接收单元,用于接收客户端发出的网络请求;数据获取单元,用于在确定未缓存所述网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对所述网络请求的响应数据和所述异步加载数据;处理单元,用于利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据;反馈单元,用于根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈。
可选地,所述后端业务逻辑可包括:后端处理逻辑和后端校验逻辑,所述客户端业务逻辑可包括:客户端处理逻辑和客户端校验逻辑;以及,处理单元可进一步用于:针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据缓存;针对所述异步加载数据执行所述客户端处理逻辑,将执行结果与所述异步加载数据合并之后利用所述客户端校验逻辑进行校验,在校验通过时将数据缓存。
可选地,反馈单元可进一步用于:将通过所述后端校验逻辑校验的数据和通过所述客户端校验逻辑校验的数据合并为反馈数据,将全部或部分反馈数据向客户端返回。
可选地,所述代理服务器可进一步包括:异常处理单元,用于在数据未通过所述后端校验逻辑或所述客户端校验逻辑的校验时,重新从后端服务器获取针对所述网络请求的响应数据或客户端的异步加载数据;在重新获取次数或监测到的后端服务器性能指标符合预设的降级策略时,使用预先缓存的降级数据并对后端服务器进行心跳检测。
可选地,代理服务器软件为OpenResty,所述后端业务逻辑和所述客户端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑和所述客户端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑和所述客户端业务逻辑采用PHP脚本实现;所述缓存可包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;所述客户端可包括:个人计算机PC端或移动终端。
为实现上述目的,根据本发明的再一个方面,提供了另一种代理服务器。
本发明实施例的代理服务器可包括:接收单元,用于接收客户端发出的网络请求;数据获取单元,用于在确定未缓存所述网络请求的请求数据时,从后端服务器获取针对所述网络请求的响应数据;反馈单元,用于利用预先缓存的后端业务逻辑处理所述响应数据,根据处理结果和所述响应数据向客户端反馈。
可选地,所述后端业务逻辑可包括:后端处理逻辑和后端校验逻辑;以及,反馈单元可进一步用于:针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据向客户端返回。
可选地,代理服务器软件为OpenResty,所述后端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑采用PHP脚本实现;所述缓存可包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;所述客户端可包括:个人计算机PC端、移动终端或内容分发网络CDN的边缘节点。
为实现上述目的,根据本发明的又一方面,提供了一种电子设备。
本发明的一种电子设备包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明所提供的代理服务器端处理网络请求的方法。
为实现上述目的,根据本发明的再一方面,提供了一种计算机可读存储介质。
本发明的一种计算机可读存储介质,其上存储有计算机程序,所述程序被处理器执行时实现本发明所提供的代理服务器端处理网络请求的方法。
根据本发明的技术方案,上述发明中的一个实施例具有如下优点或有益效果:在后端服务器和客户端的原有业务逻辑中,将部分通用性强、可缓存的处理逻辑和校验逻辑移植到代理服务器,在处理网络请求时,在代理服务器端执行上述逻辑并按需缓存相关数据(在客户端请求相同数据时可将其直接返回),从而有效减少请求数量,减轻后端服务器和客户端的计算压力和流量压力,提升后端服务器性能和网页响应速度。此外,本发明还可处理CDN网络的数据请求,在代理服务器端执行后端业务逻辑之后,将响应数据从代理服务器转发到CDN网络的边缘节点,从而优化CDN网络性能。
上述的非惯用的可选方式所具有的进一步效果将在下文中结合具体实施方式加以说明。
附图说明
附图用于更好地理解本发明,不构成对本发明的不当限定。其中:
图1是根据本发明第一实施例中代理服务器端处理网络请求的方法的主要步骤示意图;
图2是本发明第一实施例中后端服务器、代理服务器和客户端之间的交互流程示意图;
图3是根据本发明第二实施例中代理服务器端处理网络请求的方法的主要步骤示意图;
图4是应用本发明第一实施例中代理服务器端处理网络请求的方法的代理服务器的组成部分示意图;
图5是根据本发明实施例可以应用于其中的示例性系统架构图;
图6是用来实现本发明实施例中代理服务器端处理网络请求的方法的电子设备的结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
需要指出的是,在不冲突的情况下,本发明的实施例以及实施例中的技术特征可以相互结合。
图1是根据本发明第一实施例中代理服务器端处理网络请求的方法的主要步骤示意图。
如图1所示,本发明第一实施例中代理服务器端处理网络请求的方法可具体按照如下步骤执行:
步骤S101:接收客户端发出的网络请求。
在本发明实施例中,软件系统结构包括:作为系统前端的客户端、用于支撑前端信息展示的后端服务器以及为后端服务器进行网络代理的代理服务器。在本实施例中,客户端可以是个人计算机PC端或手机、平板电脑等移动终端,代理服务器软件可以是原生Nginx(一种轻量级的Web服务器、反向代理服务器以及电子邮件代理服务器)、OpenResty(一种基于Nginx的Web平台)、Apache(一种Web服务器软件)等。在本步骤中,代理服务器接收客户端发出的网络请求如超文本传输协议HTTP(HyperText Transfer Protocol)请求。
步骤S102:在确定未缓存网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对网络请求的响应数据和异步加载数据。
具体应用中,代理服务器接收到网络请求之后,首先判断是否缓存有相应的请求数据:若是,则将缓存的请求数据响应于客户端;否则,向后端服务器发送请求以获取针对网络请求的响应数据。在本发明实施例中,上述缓存的方式可以是代理服务器内存缓存、代理服务器磁盘缓存或者分布式网络缓存,上述响应数据可以是超文本标记语言HTML(HyperText Markup Language)片段、JS对象标记JSON(JavaScript Object Notation)格式数据等。
之后,代理服务器还可以判断是否缓存有客户端的异步加载数据:若是,则对缓存的异步加载数据执行后续处理;否则,向后端服务器发送请求以获取上述异步加载数据。其中,客户端的异步加载数据指的是客户端接收到请求的页面文件后需要通过JavaScript(一种直译式脚本语言)从后端服务器异步加载的数据。
步骤S103:利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据。
在本步骤中,后端业务逻辑指的是从后端服务器移植到代理服务器并进行缓存的业务逻辑,如对数据进行加工处理的后端处理逻辑(如时间戳转换、代码与网页内容的对应等)和对数据进行完整性校验(如校验各字段是否完整)、合规性校验(如校验数据是否符合目标规划)、结构性校验(如校验数据结构是否满足要求)的后端校验逻辑。客户端业务逻辑指的是从客户端移植到代理服务器并进行缓存的业务逻辑,如对异步加载数据进行加工处理的客户端处理逻辑(如关键词检测)和对异步加载数据进行完整性校验、合规性校验、结构性校验的客户端校验逻辑。需要说明的是,对数据的加工和校验均属于本步骤中“处理”的范畴,而上述后端业务逻辑和客户端业务逻辑并不限于上述处理逻辑和校验逻辑,还可以是所需的任一种业务逻辑。实际应用场景中,代理服务器还可缓存各类配置数据以供读取。
具体应用中,为了缓解后端服务器和客户端的计算压力和流量压力,代理服务器缓存的后端业务逻辑与客户端业务逻辑均为执行频率较高、通用性较强并且可缓存的业务逻辑。可以理解,从后端服务器、客户端将业务逻辑移植到代理服务器的过程并非代码的简单拷贝,而需要实现相同逻辑在不同平台、不同编程语言之间的转换。实际应用场景中,本发明可采用插件化脚本动态代理的方式实现以上逻辑,当代理服务器软件为OpenResty时,后端业务逻辑和客户端业务逻辑采用Lua脚本实现;当代理服务器软件为原生Nginx时,后端业务逻辑和客户端业务逻辑采用Shell脚本实现;当代理服务器软件为Apache时,后端业务逻辑和客户端业务逻辑采用PHP脚本实现,上述Lua、Shell、PHP均为脚本语言。可以理解的是,代理服务器软件可以使用其它的适用软件,后端业务逻辑和客户端业务逻辑也可采用其它适用的软件形式实现,只要代理服务器能够以动态插件化的方式从后端服务器获取数据并执行业务逻辑即可。
步骤S104:根据处理结果、响应数据以及异步加载数据向客户端反馈。
对应于步骤S103,本步骤中的处理结果可以是后端业务逻辑处理响应数据的结果(即处理后得到的数据)或者客户端业务逻辑处理异步加载数据的结果或者二者的结合。
在本实施例中,步骤S103中的数据处理和步骤S104中的数据反馈可以有以下三种具体实现方式:
在第一种实现方式中,既需利用后端业务逻辑处理响应数据,也需利用客户端业务逻辑处理异步加载数据。具体地,代理服务器首先针对响应数据执行后端处理逻辑,并将执行结果(即执行后得到的数据)缓存。之后,将执行结果与响应数据合并,在合并之后利用后端校验逻辑对合并后的数据进行校验,在校验通过时将合并后的数据缓存。此后,代理服务器针对异步加载数据执行客户端处理逻辑,将执行结果与异步加载数据合并,并在合并之后利用客户端校验逻辑对合并后的数据进行校验,在校验通过时将合并后的数据缓存。
此后,代理服务器将通过后端校验逻辑校验的数据(即响应数据与相应执行结果合并后的数据)和通过客户端校验逻辑校验的数据(即异步加载数据与相应执行结果合并后的数据)合并为反馈数据,将全部或部分反馈数据向客户端返回。实际应用中,对于部分网络请求,代理服务器可将全部反馈数据向客户端返回;而在某些依赖外部逻辑(例如判断用户等级)进行反馈的场景中,代理服务器可根据上述外部逻辑向客户端返回部分反馈数据,之后可根据客户端发送的后续请求将另一部分反馈数据返回。
需要说明的是,在上述实现方式中,后端业务逻辑可以只是后端处理逻辑和后端校验逻辑中的一种,客户端业务逻辑也可以是客户端处理逻辑和客户端校验逻辑中的一种,在此情况下,步骤S103中的处理结果为当前逻辑的处理结果,在步骤S104中将处理结果、响应数据与异步加载数据整合后向客户端反馈。
在第二种实现方式中,只需利用后端业务逻辑处理响应数据,不需利用客户端业务逻辑处理异步加载数据。具体地,代理服务器首先针对响应数据执行后端处理逻辑,将执行结果与响应数据合并,并在合并之后利用后端校验逻辑对合并后的数据进行校验,在校验通过时将合并后的数据缓存。之后,代理服务器将通过后端校验逻辑校验的数据和异步记载数据合并为反馈数据,将全部或部分反馈数据向客户端返回。
在第三种实现方式中,不需利用后端业务逻辑处理响应数据,只需利用客户端业务逻辑处理异步加载数据。具体地,代理服务器针对异步加载数据执行客户端处理逻辑,将执行结果与异步加载数据合并,并在合并之后利用客户端校验逻辑对合并后的数据进行校验,在校验通过时将合并后的数据缓存。此后,代理服务器将通过客户端校验逻辑校验的数据和响应数据合并为反馈数据,将全部或部分反馈数据向客户端返回。
这样,本发明以上述三种方式实现了数据处理以及客户端反馈。实际应用中,当存在非法数据或者后端服务器因性能下降返回错误数据时,校验无法通过,此时可重新从后端服务器获取响应数据或异步加载数据。如果重新获取次数或监测到的后端服务器性能指标(例如TP99,TP99是一种响应时间的百分线TP<Top Percentile>指标,其物理含义为:将统计周期内采集的多个响应时间从小到大排序,位于第99%的响应时间)符合预设的降级策略(如重新获取次数大于次数阈值或者TP99大于响应时间阈值),可使用预先缓存的降级数据(即默认数据)向客户端反馈并对后端服务器进行心跳检测。
图2是本实施例中后端服务器、代理服务器和客户端之间的一个交互流程示意图。
如图2所示,代理服务器既需利用后端业务逻辑处理响应数据,也需利用客户端业务逻辑处理异步加载数据。
具体地,后端服务器、代理服务器和客户端的完整交互通过以下步骤实现:步骤201,客户端向代理服务器发送网络请求。步骤202,代理服务器查询缓存,如果缓存中有网络请求的请求数据则执行步骤203将请求数据响应到客户端,如果缓存中无上述请求数据,则执行步骤204向后端服务器发送请求。步骤205,后端服务器向代理服务器返回针对上述网络请求的响应数据。步骤206,代理服务器针对响应数据执行后端处理逻辑。步骤207,代理服务器将执行后端处理逻辑的结果与响应数据合并,并利用后端校验逻辑对其进行校验。步骤208,代理服务器获取客户端的异步加载数据。步骤209,代理服务器针对异步加载数据执行客户端处理逻辑。步骤210,代理服务器将执行客户端处理逻辑的结果与异步加载数据合并,并利用客户端校验逻辑对其进行校验。步骤211,代理服务器将通过校验的数据缓存。如果数据未通过校验则执行步骤212重新请求后端服务器。步骤213,代理服务器将通过校验的数据组装(即合并)为反馈数据并根据外部逻辑将部分反馈数据返回客户端。步骤214,客户端在外部逻辑触发下发出下一个网络请求。步骤215,代理服务器根据外部逻辑将另一部分反馈数据返回客户端。
通过上述设置,本发明可预先将后端业务逻辑前移到代理服务器、将客户端业务逻辑后移到代理服务器。在处理网络请求时,即可由代理服务器执行上述逻辑并按需缓存相关数据,由此可减少后端服务器与客户端的交互次数,减轻后端服务器与客户端的流量压力,提升用户的浏览体验。
图3是根据本发明第二实施例中代理服务器端处理网络请求的方法的主要步骤示意图。
如图3所示,本实施例的代理服务器端处理网络请求的方法可根据以下步骤执行:
步骤S301:接收客户端发出的网络请求。
在本步骤中,代理服务器接收PC端或移动终端等客户端发出的网络请求。特别地,在本实施例中,客户端还可以是内容分发网络CDN的边缘节点(即接近用户的节点服务器)。
步骤S302:在确定未缓存网络请求的请求数据时,从后端服务器获取针对网络请求的响应数据。
具体应用中,代理服务器接收到网络请求之后,首先判断是否缓存有相应的请求数据:若是,则将缓存的请求数据响应于客户端;否则,向后端服务器发送请求以获取针对网络请求的响应数据。在本发明实施例中,上述缓存的方式可以是代理服务器内存缓存、代理服务器磁盘缓存或者分布式网络缓存。
步骤S303:利用预先缓存的后端业务逻辑处理响应数据,根据处理结果和响应数据向客户端反馈。
在本步骤中,后端业务逻辑包括对异步加载数据进行加工处理的后端处理逻辑或者对响应数据进行完整性校验、合规性校验、结构性校验的后端校验逻辑,后端校验逻辑也可以是后端处理逻辑和后端校验逻辑的结合。可以理解,上述后端业务逻辑为执行频率较高、通用性较强并且可缓存的业务逻辑。实际应用场景中,本发明采用插件化脚本动态代理的方式实现以上逻辑,当代理服务器软件为OpenResty时,后端业务逻辑采用Lua脚本实现;当代理服务器软件为原生Nginx时,后端业务逻辑采用Shell脚本实现;当代理服务器软件为Apache时,后端业务逻辑采用PHP脚本实现。
本步骤中的数据处理和反馈可通过以下三种具体方式实现。
在第一种方式中,后端业务逻辑包括后端处理逻辑和后端校验逻辑。此时,首先代理服务器需针对响应数据执行后端处理逻辑,将执行结果与响应数据合并,并在合并之后利用后端校验逻辑对合并后的数据进行校验,在校验通过时将合并后的数据缓存并将该数据全部向客户端反馈。
在第二种方式中,后端业务逻辑为后端处理逻辑。此时,首先代理服务器需针对响应数据执行后端处理逻辑,之后将执行结果与响应数据合并,最后将合并后的数据全部向客户端反馈。
在第三种方式中,后端业务逻辑为后端校验逻辑。此时,首先代理服务器针对响应数据执行后端校验逻辑,并在校验通过时将数据缓存并向客户端反馈。如果上述校验无法通过,可重新从后端服务器获取响应数据再次校验。如果重新获取次数或监测到的后端服务器性能指标符合预设的降级策略时,可使用预先缓存的降级数据向客户端反馈并对后端服务器进行心跳检测。
在本实施例的技术方案中,代理服务器可单独截取后端服务器返回的响应数据执行后端业务逻辑,并直接向CDN边缘节点等客户端返回,从而减轻后端服务器的流量压力和计算压力,提升CDN网络的性能。
图4是应用本发明第一实施例中代理服务器端处理网络请求的方法的代理服务器的组成部分示意图。
如图4所示,上述代理服务器400包括:接收单元401、数据获取单元402、处理单元403和反馈单元404。其中:
接收单元401可用于接收客户端发出的网络请求;
数据获取单元402可用于在确定未缓存所述网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对所述网络请求的响应数据和所述异步加载数据;
处理单元403可用于利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据;
反馈单元404可用于根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈。
在本发明实施例中,所述后端业务逻辑包括:后端处理逻辑和后端校验逻辑,所述客户端业务逻辑包括:客户端处理逻辑和客户端校验逻辑;处理单元403可进一步用于:针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据缓存;针对所述异步加载数据执行所述客户端处理逻辑,将执行结果与所述异步加载数据合并之后利用所述客户端校验逻辑进行校验,在校验通过时将数据缓存。
作为一个优选方案,反馈单元404可进一步用于:将通过所述后端校验逻辑校验的数据和通过所述客户端校验逻辑校验的数据合并为反馈数据,将全部或部分反馈数据向客户端返回。
较佳地,在本发明实施例中,所述代理服务器400可进一步包括异常处理单元,其用于在数据未通过所述后端校验逻辑或所述客户端校验逻辑的校验时,重新从后端服务器获取针对所述网络请求的响应数据或客户端的异步加载数据;在重新获取次数或监测到的后端服务器性能指标符合预设的降级策略时,使用预先缓存的降级数据并对后端服务器进行心跳检测。
此外,在本发明实施例中,代理服务器软件为OpenResty,所述后端业务逻辑和所述客户端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑和所述客户端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑和所述客户端业务逻辑采用PHP脚本实现;所述缓存可包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;所述客户端可包括:个人计算机PC端或移动终端。
在本发明实施例的技术方案中,可预先将后端业务逻辑前移到代理服务器、将客户端业务逻辑后移到代理服务器。在处理网络请求时,即可由代理服务器执行上述逻辑并按需缓存相关数据,由此可减少后端服务器与客户端的交互次数,减轻后端服务器与客户端的流量压力,提升用户的浏览体验。
下面介绍应用本发明第二实施例中代理服务器端处理网络请求的方法的代理服务器的组成部分示意图。
具体地,上述代理服务器可包括接收单元、数据获取单元和反馈单元。其中:接收单元可用于接收客户端发出的网络请求;数据获取单元可用于在确定未缓存所述网络请求的请求数据时,从后端服务器获取针对所述网络请求的响应数据;反馈单元可用于利用预先缓存的后端业务逻辑处理所述响应数据,根据处理结果和所述响应数据向客户端反馈。
实际应用中,所述后端业务逻辑可包括:后端处理逻辑和后端校验逻辑;而反馈单元可进一步用于:针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据向客户端返回。
在本发明实施例中,代理服务器软件为OpenResty,所述后端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑采用PHP脚本实现;所述缓存可包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;所述客户端可包括:个人计算机PC端、移动终端或内容分发网络CDN的边缘节点。
图5示出了可以应用本发明实施例的代理服务器端处理网络请求的方法的示例性系统架构500。
如图5所示,系统架构500可以包括客户端设备501、502、503,网络504,代理服务器505和后端服务器506(此架构仅仅是示例,具体架构中包含的组件可以根据申请具体情况调整)。网络504用以在客户端设备501、502、503和代理服务器505之间提供通信链路的介质。网络504可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用客户端设备501、502、503通过网络504与代理服务器505交互。客户端设备501、502、503上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等(仅为示例)。
客户端设备501、502、503可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
后端服务器506可以是提供各种服务的服务器,例如对用户利用客户端设备501、502、503所浏览的网站提供支持的WEB服务器(仅为示例)。后端服务器506可以对接收到的网络请求进行处理,并将处理结果(例如网页内容--仅为示例)通过代理服务器505反馈给客户端设备。
显然,本发明实施例所提供的代理服务器端处理网络请求的方法一般由代理服务器505执行。
应该理解,图5中的客户端设备、网络、代理服务器、后端服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的客户端设备、网络、代理服务器和后端服务器。
本发明还提供了一种电子设备。本发明实施例的电子设备包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明所提供的代理服务器端处理网络请求的方法。
下面参考图6,其示出了适于用来实现本发明实施例的电子设备的计算机系统600的结构示意图。图6示出的电子设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图6所示,计算机系统600包括中央处理单元(CPU)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM603中,还存储有计算机系统600操作所需的各种程序和数据。CPU601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
以下部件连接至I/O接口605:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便从其上读出的计算机程序根据需要被安装入存储部分608。
特别地,根据本发明公开的实施例,上文的主要步骤图描述的过程可以被实现为计算机软件程序。例如,本发明实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行主要步骤图所示的方法的程序代码。在上述实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被中央处理单元601执行时,执行本发明的系统中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。在本发明中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这根据所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括接收单元、数据获取单元、处理单元和反馈单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,接收单元还可以被描述为“向数据获取单元发送网络请求的单元”。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中的。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该设备执行时,使得该设备执行的步骤包括:接收客户端发出的网络请求;在确定未缓存所述网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对所述网络请求的响应数据和所述异步加载数据;利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据;根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈。
在本发明实施例的技术方案中,可预先将后端业务逻辑前移到代理服务器、将客户端业务逻辑后移到代理服务器。在处理网络请求时,即可由代理服务器执行上述逻辑并按需缓存相关数据,由此可减少后端服务器与客户端的交互次数,减轻后端服务器与客户端的流量压力,提升用户的浏览体验。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。

Claims (18)

1.一种代理服务器端处理网络请求的方法,其特征在于,包括:
接收客户端发出的网络请求;
在确定未缓存所述网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对所述网络请求的响应数据和所述异步加载数据;
利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据;以及,
根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈。
2.根据权利要求1所述的方法,其特征在于,所述后端业务逻辑包括:后端处理逻辑和后端校验逻辑,所述客户端业务逻辑包括:客户端处理逻辑和客户端校验逻辑;以及,所述利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据,具体包括:
针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据缓存;针对所述异步加载数据执行所述客户端处理逻辑,将执行结果与所述异步加载数据合并之后利用所述客户端校验逻辑进行校验,在校验通过时将数据缓存。
3.根据权利要求2所述的方法,其特征在于,所述根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈,具体包括:
将通过所述后端校验逻辑校验的数据和通过所述客户端校验逻辑校验的数据合并为反馈数据,将全部或部分反馈数据向客户端返回。
4.根据权利要求2所述的方法,其特征在于,所述方法进一步包括:
在数据未通过所述后端校验逻辑或所述客户端校验逻辑的校验时,重新从后端服务器获取针对所述网络请求的响应数据或客户端的异步加载数据;
在重新获取次数或监测到的后端服务器性能指标符合预设的降级策略时,使用预先缓存的降级数据并对后端服务器进行心跳检测。
5.根据权利要求1-4任一所述的方法,其特征在于,
代理服务器软件为OpenResty,所述后端业务逻辑和所述客户端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑和所述客户端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑和所述客户端业务逻辑采用PHP脚本实现;
所述缓存包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;
所述客户端包括:个人计算机PC端或移动终端。
6.一种代理服务器端处理网络请求的方法,其特征在于,包括:
接收客户端发出的网络请求;
在确定未缓存所述网络请求的请求数据时,从后端服务器获取针对所述网络请求的响应数据;以及,
利用预先缓存的后端业务逻辑处理所述响应数据,根据处理结果和所述响应数据向客户端反馈。
7.根据权利要求6所述的方法,其特征在于,所述后端业务逻辑包括:后端处理逻辑和后端校验逻辑;以及,所述利用预先缓存的后端业务逻辑处理所述响应数据,根据处理结果和所述响应数据向客户端反馈包括:
针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据向客户端返回。
8.根据权利要求6或7所述的方法,其特征在于,
代理服务器软件为OpenResty,所述后端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑采用PHP脚本实现;
所述缓存包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;
所述客户端包括:个人计算机PC端、移动终端或内容分发网络CDN的边缘节点。
9.一种代理服务器,其特征在于,包括:
接收单元,用于接收客户端发出的网络请求;
数据获取单元,用于在确定未缓存所述网络请求的请求数据和客户端的异步加载数据时,从后端服务器获取针对所述网络请求的响应数据和所述异步加载数据;
处理单元,用于利用预先缓存的后端业务逻辑处理所述响应数据、和/或利用预先缓存的客户端业务逻辑处理所述异步加载数据;
反馈单元,用于根据处理结果、所述响应数据以及所述异步加载数据向客户端反馈。
10.根据权利要求9所述的代理服务器,其特征在于,所述后端业务逻辑包括:后端处理逻辑和后端校验逻辑,所述客户端业务逻辑包括:客户端处理逻辑和客户端校验逻辑;以及,处理单元进一步用于:
针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据缓存;针对所述异步加载数据执行所述客户端处理逻辑,将执行结果与所述异步加载数据合并之后利用所述客户端校验逻辑进行校验,在校验通过时将数据缓存。
11.根据权利要求10所述的代理服务器,其特征在于,反馈单元进一步用于:
将通过所述后端校验逻辑校验的数据和通过所述客户端校验逻辑校验的数据合并为反馈数据,将全部或部分反馈数据向客户端返回。
12.根据权利要求10所述的代理服务器,其特征在于,所述代理服务器进一步包括:
异常处理单元,用于在数据未通过所述后端校验逻辑或所述客户端校验逻辑的校验时,重新从后端服务器获取针对所述网络请求的响应数据或客户端的异步加载数据;在重新获取次数或监测到的后端服务器性能指标符合预设的降级策略时,使用预先缓存的降级数据并对后端服务器进行心跳检测。
13.根据权利要求9-12任一所述的代理服务器,其特征在于,
代理服务器软件为OpenResty,所述后端业务逻辑和所述客户端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑和所述客户端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑和所述客户端业务逻辑采用PHP脚本实现;
所述缓存包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;
所述客户端包括:个人计算机PC端或移动终端。
14.一种代理服务器,其特征在于,包括:
接收单元,用于接收客户端发出的网络请求;
数据获取单元,用于在确定未缓存所述网络请求的请求数据时,从后端服务器获取针对所述网络请求的响应数据;
反馈单元,用于利用预先缓存的后端业务逻辑处理所述响应数据,根据处理结果和所述响应数据向客户端反馈。
15.根据权利要求14所述的代理服务器,其特征在于,所述后端业务逻辑包括:后端处理逻辑和后端校验逻辑;以及,反馈单元进一步用于:
针对所述响应数据执行所述后端处理逻辑,将执行结果与所述响应数据合并之后利用所述后端校验逻辑进行校验,在校验通过时将数据向客户端返回。
16.根据权利要求14或15所述的代理服务器,其特征在于,
代理服务器软件为OpenResty,所述后端业务逻辑采用Lua脚本实现;或者,代理服务器软件为原生Nginx,所述后端业务逻辑采用Shell脚本实现;或者,代理服务器软件为Apache,所述后端业务逻辑采用PHP脚本实现;
所述缓存包括:代理服务器内存缓存、代理服务器磁盘缓存、分布式网络缓存;
所述客户端包括:个人计算机PC端、移动终端或内容分发网络CDN的边缘节点。
17.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-5中任一所述的方法。
18.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求1-5中任一所述的方法。
CN201810688252.6A 2018-06-28 2018-06-28 代理服务器端处理网络请求的方法和代理服务器 Active CN110661826B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810688252.6A CN110661826B (zh) 2018-06-28 2018-06-28 代理服务器端处理网络请求的方法和代理服务器

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810688252.6A CN110661826B (zh) 2018-06-28 2018-06-28 代理服务器端处理网络请求的方法和代理服务器

Publications (2)

Publication Number Publication Date
CN110661826A true CN110661826A (zh) 2020-01-07
CN110661826B CN110661826B (zh) 2023-06-02

Family

ID=69027356

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810688252.6A Active CN110661826B (zh) 2018-06-28 2018-06-28 代理服务器端处理网络请求的方法和代理服务器

Country Status (1)

Country Link
CN (1) CN110661826B (zh)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111682983A (zh) * 2020-06-04 2020-09-18 北京达佳互联信息技术有限公司 界面显示方法、装置、终端及服务器
CN112699152A (zh) * 2021-01-07 2021-04-23 北京金万维科技有限公司 一种基于OpenResty实现的缓存方法
CN113329043A (zh) * 2020-02-28 2021-08-31 中国移动通信集团福建有限公司 一种数据服务提供方法及装置
WO2021258575A1 (zh) * 2020-06-22 2021-12-30 北京旷视科技有限公司 请求处理系统、方法、装置、电子设备和计算机可读介质
CN114531489A (zh) * 2022-01-14 2022-05-24 北京字节跳动网络技术有限公司 一种请求响应方法及装置
CN114614996A (zh) * 2022-05-12 2022-06-10 深圳市华曦达科技股份有限公司 一种终端请求处理方法、装置及系统
CN115348317A (zh) * 2022-08-12 2022-11-15 北明成功软件(山东)有限公司 一种实现web系统即时通信的方法、装置和系统

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101997854A (zh) * 2009-08-31 2011-03-30 阿里巴巴集团控股有限公司 一种提供数据服务的处理系统及方法
CN102571947A (zh) * 2011-12-29 2012-07-11 奇智软件(北京)有限公司 一种代理处理数据的方法、装置和系统
US8516041B1 (en) * 2011-05-18 2013-08-20 Amazon Technologies, Inc. Pre-fetching asynchronously requested content
CN103269377A (zh) * 2013-05-31 2013-08-28 北京奇虎科技有限公司 处理脚本文件的方法、服务器、客户端和系统
US20150032803A1 (en) * 2013-07-29 2015-01-29 John Graham-Cumming Method and apparatus for reducing loading time of web pages
CN104618444A (zh) * 2014-12-30 2015-05-13 北京奇虎科技有限公司 一种基于反向代理服务器处理请求的方法和装置
CN106453536A (zh) * 2016-09-29 2017-02-22 车智互联(北京)科技有限公司 一种网络请求处理方法、服务器和系统
CN107070991A (zh) * 2017-03-08 2017-08-18 四川驹马企业管理有限公司 网络数据缓存装置与系统
CN107704582A (zh) * 2017-10-08 2018-02-16 安徽康佳电子有限公司 一种基于服务器和网页的闭环生态反馈链系统

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101997854A (zh) * 2009-08-31 2011-03-30 阿里巴巴集团控股有限公司 一种提供数据服务的处理系统及方法
US8516041B1 (en) * 2011-05-18 2013-08-20 Amazon Technologies, Inc. Pre-fetching asynchronously requested content
CN102571947A (zh) * 2011-12-29 2012-07-11 奇智软件(北京)有限公司 一种代理处理数据的方法、装置和系统
CN103269377A (zh) * 2013-05-31 2013-08-28 北京奇虎科技有限公司 处理脚本文件的方法、服务器、客户端和系统
US20150032803A1 (en) * 2013-07-29 2015-01-29 John Graham-Cumming Method and apparatus for reducing loading time of web pages
CN104618444A (zh) * 2014-12-30 2015-05-13 北京奇虎科技有限公司 一种基于反向代理服务器处理请求的方法和装置
CN106453536A (zh) * 2016-09-29 2017-02-22 车智互联(北京)科技有限公司 一种网络请求处理方法、服务器和系统
CN107070991A (zh) * 2017-03-08 2017-08-18 四川驹马企业管理有限公司 网络数据缓存装置与系统
CN107704582A (zh) * 2017-10-08 2018-02-16 安徽康佳电子有限公司 一种基于服务器和网页的闭环生态反馈链系统

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113329043A (zh) * 2020-02-28 2021-08-31 中国移动通信集团福建有限公司 一种数据服务提供方法及装置
CN111682983A (zh) * 2020-06-04 2020-09-18 北京达佳互联信息技术有限公司 界面显示方法、装置、终端及服务器
WO2021258575A1 (zh) * 2020-06-22 2021-12-30 北京旷视科技有限公司 请求处理系统、方法、装置、电子设备和计算机可读介质
CN112699152A (zh) * 2021-01-07 2021-04-23 北京金万维科技有限公司 一种基于OpenResty实现的缓存方法
CN114531489A (zh) * 2022-01-14 2022-05-24 北京字节跳动网络技术有限公司 一种请求响应方法及装置
CN114614996A (zh) * 2022-05-12 2022-06-10 深圳市华曦达科技股份有限公司 一种终端请求处理方法、装置及系统
CN114614996B (zh) * 2022-05-12 2023-03-28 深圳市华曦达科技股份有限公司 一种终端请求处理方法、装置及系统
CN115348317A (zh) * 2022-08-12 2022-11-15 北明成功软件(山东)有限公司 一种实现web系统即时通信的方法、装置和系统
CN115348317B (zh) * 2022-08-12 2024-03-29 北明成功软件(山东)有限公司 一种实现web系统即时通信的方法、装置和系统

Also Published As

Publication number Publication date
CN110661826B (zh) 2023-06-02

Similar Documents

Publication Publication Date Title
CN110661826B (zh) 代理服务器端处理网络请求的方法和代理服务器
US10110695B1 (en) Key resource prefetching using front-end optimization (FEO) configuration
US9055118B2 (en) Edge caching using HTTP headers
US11017153B2 (en) Optimizing loading of web page based on aggregated user preferences for web page elements of web page
US8966053B2 (en) Methods and systems for performing a prefetch abort operation for network acceleration
US9055124B1 (en) Enhanced caching of network content
US9917908B1 (en) Third party validation of web content
US9253278B2 (en) Using entity tags (ETags) in a hierarchical HTTP proxy cache to reduce network traffic
US20100146415A1 (en) Dns prefetch
CN109992406B (zh) 图片请求方法、响应图片请求的方法及客户端
CN110874227A (zh) 实现于api网关的灰度发布的分流方法、系统和电子设备
US20200320154A1 (en) A webpage loading method, webpage loading system and server
US20180302489A1 (en) Architecture for proactively providing bundled content items to client devices
CN112003945A (zh) 服务请求响应方法及装置
CN107357526B (zh) 用于处理网络数据的方法和装置、服务器和存储介质
CN113452733A (zh) 文件下载方法和装置
CN112182445A (zh) 一种优化客户端页面性能的方法和装置
US9378178B1 (en) Enhancing HTTP caching by allowing content sharing of data blocks across resources identified by different uniform resource locators
CN112149392A (zh) 一种富文本编辑方法和装置
US9674220B2 (en) System and method thereof for optimizing delivery of content over a network
CN113360815A (zh) 一种请求重试方法和装置
CN111953718A (zh) 一种页面调试方法和装置
CN113271300B (zh) 一种认证的系统和方法
CN112688982B (zh) 一种用户请求处理方法和装置
CN113132447A (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