CN103401946B - Http上传加速方法和系统 - Google Patents
Http上传加速方法和系统 Download PDFInfo
- Publication number
- CN103401946B CN103401946B CN201310362191.1A CN201310362191A CN103401946B CN 103401946 B CN103401946 B CN 103401946B CN 201310362191 A CN201310362191 A CN 201310362191A CN 103401946 B CN103401946 B CN 103401946B
- Authority
- CN
- China
- Prior art keywords
- upload
- request
- source station
- http
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Abstract
本发明公开了一种HTTP上传加速方法和系统,对于满足一定条件的HTTP上传请求,可以减少响应时间,提高响应速度,同时也可以减轻CDN服务节点的压力。其技术方案为:源站进行上传配置;用户通过上传配置上传静态数据;内容分发网络节点接收请求;内容分发网络节点判断接收到的请求是否适用上传加速功能;若请求不适用上传加速功能,则上传数据到源站,接收源站返回的响应,并发送响应给用户;若请求适用上传加速功能,则在用户数据上传完成后给用户发送响应,并将数据保存在本地缓存中,并在其后的任意时刻将本地缓存中的数据同步到源站。
Description
技术领域
本发明涉及HTTP上传加速技术,尤其涉及内容分发网络(CDN)中的HTTP上传加速方法和系统。
背景技术
内容分发网络(CDN)的基本原理是:通过在互联网中各处放置节点服务器,构成在现有的互联网基础之上的一层智能虚拟网络,将使用CDN服务的网站内容发布到最接近用户的CDN节点内,使用户可以就近取得所需的内容,从而可以解决Internet网络的拥塞状况,提高用户访问网站的响应速度。
内容分发网络的核心思想在于将网站的内容发布到网络各处,通过减少网站内容在网络上的长距离传输来减少响应时间。
然而,这种机制适用于用户从HTTP服务器获取内容,却不适用于用户上传内容到HTTP服务器。这是由于用户上传内容时不使用源站的缓存,无法通过减少网络传输距离而缩短上传时间。实际上,目前主流CDN厂商使用的CDN软件(如squid等)对于HTTP上传只起到反向代理的作用,没有加速效果。
发明内容
本发明的目的在于解决上述问题,提供了一种HTTP上传加速方法和系统,对于满足一定条件的HTTP上传请求,可以减少响应时间,提高响应速度,同时也可以减轻CDN服务节点的压力。
本发明的技术方案为:本发明揭示了一种HTTP上传加速方法,包括:
源站进行上传配置;
用户通过上传配置上传静态数据;
内容分发网络节点接收请求;
内容分发网络节点判断接收到的请求是否适用上传加速功能;
若请求不适用上传加速功能,则上传数据到源站,接收源站返回的响应,并发送响应给用户;
若请求适用上传加速功能,则在用户数据上传完成后给用户发送响应,并将数据保存在本地缓存中,并在其后的任意时刻将本地缓存中的数据同步到源站。
根据本发明的HTTP上传加速方法的一实施例,源站进行上传配置的步骤包括:
源站在HTTP上传请求中给上传的数据赋予唯一的URL值。
根据本发明的HTTP上传加速方法的一实施例,URL值置于HTTP上传请求的自定义的HTTP头部或者URL作为参数传递。
根据本发明的HTTP上传加速方法的一实施例,在判断接收到的请求是否适用上传加速功能的步骤中,是根据请求中是否携带自定义的HTTP头部或者上传请求本身的URL是否满足上传加速的规则。
根据本发明的HTTP上传加速方法的一实施例,内容分发网络节点和源站之间以HTTP协议将上传的数据同步到源站。
本发明还揭示了一种HTTP上传加速系统,包括:
上传配置装置,源站进行上传配置;
上传装置,用户通过上传配置上传静态数据;
请求接收装置,内容分发网络节点接收请求;
加速判断装置,内容分发网络节点判断接收到的请求是否适用上传加速功能;
普通上传响应装置,若请求不适用上传加速功能,则上传数据到源站,接收源站返回的响应,并发送响应给用户;
加速上传响应装置,若请求适用上传加速功能,则在用户数据上传完成后给用户发送响应,并将数据保存在本地缓存中,并在其后的任意时刻将本地缓存中的数据同步到源站。
根据本发明的HTTP上传加速系统的一实施例,上传配置装置实现源站在HTTP上传请求中给上传的数据赋予唯一的URL值。
根据本发明的HTTP上传加速系统的一实施例,URL值置于HTTP上传请求的自定义的HTTP头部或者URL作为参数传递。
根据本发明的HTTP上传加速系统的一实施例,加速判断装置是根据请求中是否携带自定义的HTTP头部或者上传请求本身的URL是否满足上传加速的规则来判断。
根据本发明的HTTP上传加速系统的一实施例,加速上传响应装置实现内容分发网络节点和源站之间以HTTP协议将上传的数据同步到源站。
本发明对比现有技术有如下的有益效果:对于不需要交互处理的静态数据(比如上传的图片、文件等),内容分发网络节点在将其上传到源站之前即给用户发送响应,从而减少响应时间,提高响应速度,同时也可以减轻CDN服务节点的压力。
附图说明
图1示出了本发明的HTTP上传加速方法的较佳实施例的流程图。
图2示出了本发明的HTTP上传加速系统的较佳实施例的结构图。
具体实施方式
下面结合附图和实施例对本发明作进一步的描述。
HTTP上传加速方法的实施例
图1示出了本发明的HTTP上传加速方法的较佳实施例的流程。请参见图1,下面是对本实施例的上传加速方法的实施步骤的详细描述。
步骤S11:源站进行上传配置。
上传页面在客户端本地生成一个唯一不重复的URL,这个URL将作为上传数据在网络上的URL,上传完成后用户可以通过这个URL再次访问该数据。用户上传数据时,客户端发出的HTTP请求应该携带这个URL(可以通过在上传POST请求的URL中作为参数传递,或者通过自定义的HTTP头携带)。
步骤S12:用户通过上传配置上传静态数据。
通过HTTP协议上传的内容通常可以分为两类:一类是需要源站进行交互处理的数据(比如登录用户名和密码),一类是不需要交互处理的静态数据(比如上传的图片、文件等)。对于第一类数据,必须将其上传到源站并通过源站处理后才能获得正确的响应,但对于第二类数据,由于是不需要交互处理的,CDN节点可以在将其上传到源站之前即给用户发送响应,从而减少响应时间。
步骤S13:容分发网络节点接收请求。
步骤S14:内容分发网络节点判断接收到的请求是否适用上传加速功能,若可加速则执行步骤S15,若不可加速则执行步骤S17。
通过判断POST请求是否携带上述自定义HTTP头或者POST请求的URL是否满足特定规则等,来判断接收到的请求是否适用上传加速功能。
步骤S15:将内容分发网络节点的本地缓存中的数据响应给用户,其中本地缓存的数据是接收来自用户上传的静态数据。
其中浏览器连接的CDN节点在接收完所有数据后给浏览器发送响应,并将数据缓存在本地,记录其URL为HTTP请求头中的URL。用户再次请求上传的文件时,无论此时CDN节点有没有把文件同步到源站,都可以以本地缓存进行响应。
步骤S16:在任意时刻将本地缓存中的数据同步到源站。
在任意时刻,源站和CDN节点之间以HTTP协议或其他任意方式把用户上传的数据同步到源站。既可以把每个用户上传的数据单独同步到源站,也可以把所有用户上传的数据一次性同步到源站。
步骤S17:上传数据到源站。
步骤S18:接收源站返回的响应。
步骤S19:发送响应给用户。
HTTP上传加速系统的实施例
图2示出了本发明的HTTP上传加速系统的较佳实施例的结构,请参见图2,本实施例的上传加速系统包括:上传配置装置1、上传装置2、请求接收装置3、加速判断装置4、普通上传响应装置5、加速上传响应装置6。
上传配置装置1的输出端连接上传装置2,上传装置2的输出端连接请求接收装置3,请求接收装置3的输出端连接加速判断装置4,加速判断装置4的输出端分别连接普通上传响应装置5和加速上传响应装置6。
上传配置装置1中,源站进行上传配置,实现源站在HTTP上传请求中给上传的数据赋予唯一的URL值,URL值置于HTTP上传请求的自定义的HTTP头部或者URL作为参数传递。
上传装置2中,用户通过上传配置上传静态数据。
请求接收装置3中,内容分发网络节点接收请求。
加速判断装置4中,内容分发网络节点判断接收到的请求是否适用上传加速功能,在本实施例中,是根据请求中是否携带自定义的HTTP头部或者上传请求本身的URL是否满足上传加速的规则来判断。
普通上传响应装置5中,若请求不适用上传加速功能,则上传数据到源站,接收源站返回的响应,并发送响应给用户。
加速上传响应装置6中,若请求适用上传加速功能,则在用户数据上传完成后给用户发送响应,并将数据保存在本地缓存中,并在其后的任意时刻以HTTP协议将本地缓存中的数据同步到源站。
上述实施例是提供给本领域普通技术人员来实现和使用本发明的,本领域普通技术人员可在不脱离本发明的发明思想的情况下,对上述实施例做出种种修改或变化,因而本发明的保护范围并不被上述实施例所限,而应该是符合权利要求书所提到的创新性特征的最大范围。
Claims (4)
1.一种HTTP上传加速方法,包括:
源站进行上传配置,其中源站在HTTP上传请求中给上传的数据赋予唯一的URL值,URL值置于HTTP上传请求的自定义的HTTP头部或者URL作为参数传递;
用户通过上传配置上传静态数据;
内容分发网络节点接收请求;
内容分发网络节点判断接收到的请求是否适用上传加速功能,其中根据请求中是否携带自定义的HTTP头部或者上传请求本身的URL是否满足上传加速的规则;
若请求不适用上传加速功能,则上传数据到源站,接收源站返回的响应,并发送响应给用户;
若请求适用上传加速功能,则在用户数据上传完成后给用户发送响应,并将数据保存在本地缓存中,并在其后的任意时刻将本地缓存中的数据同步到源站。
2.根据权利要求1所述的HTTP上传加速方法,其特征在于,内容分发网络节点和源站之间以HTTP协议将上传的数据同步到源站。
3.一种HTTP上传加速系统,包括:
上传配置装置,源站进行上传配置,其中源站在HTTP上传请求中给上传的数据赋予唯一的URL值,URL值置于HTTP上传请求的自定义的HTTP头部或者URL作为参数传递;
上传装置,用户通过上传配置上传静态数据;
请求接收装置,内容分发网络节点接收请求;
加速判断装置,内容分发网络节点判断接收到的请求是否适用上传加速功能,其中根据请求中是否携带自定义的HTTP头部或者上传请求本身的URL是否满足上传加速的规则来判断;
普通上传响应装置,若请求不适用上传加速功能,则上传数据到源站,接收源站返回的响应,并发送响应给用户;
加速上传响应装置,若请求适用上传加速功能,则在用户数据上传完成后给用户发送响应,并将数据保存在本地缓存中,并在其后的任意时刻将本地缓存中的数据同步到源站。
4.根据权利要求3所述的HTTP上传加速系统,其特征在于,加速上传响应装置实现内容分发网络节点和源站之间以HTTP协议将上传的数据同步到源站。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201310362191.1A CN103401946B (zh) | 2013-08-19 | 2013-08-19 | Http上传加速方法和系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201310362191.1A CN103401946B (zh) | 2013-08-19 | 2013-08-19 | Http上传加速方法和系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN103401946A CN103401946A (zh) | 2013-11-20 |
CN103401946B true CN103401946B (zh) | 2016-07-13 |
Family
ID=49565469
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201310362191.1A Active CN103401946B (zh) | 2013-08-19 | 2013-08-19 | Http上传加速方法和系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN103401946B (zh) |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103944992B (zh) * | 2014-04-25 | 2017-04-26 | 厦门享游网络科技有限公司 | 一种在ios上加速http的方法 |
CN104754042A (zh) * | 2015-03-13 | 2015-07-01 | 网宿科技股份有限公司 | 一种使用cdn的图片发布上传加速方法及系统 |
CN106230782A (zh) * | 2016-07-20 | 2016-12-14 | 腾讯科技(深圳)有限公司 | 一种基于内容分发网络的信息处理方法及装置 |
CN107580021A (zh) * | 2017-08-01 | 2018-01-12 | 北京奇艺世纪科技有限公司 | 一种文件传输的方法和装置 |
CN107707616B (zh) * | 2017-08-21 | 2019-02-12 | 贵州白山云科技股份有限公司 | 一种数据传输方法及系统 |
CN107566469B (zh) * | 2017-08-24 | 2020-06-05 | 平安科技(深圳)有限公司 | 用户信息上载方法、装置及计算机可读存储介质 |
CN108401011B (zh) * | 2018-01-30 | 2021-09-24 | 网宿科技股份有限公司 | 内容分发网络中握手请求的加速方法、设备及边缘节点 |
CN109450991A (zh) * | 2018-10-19 | 2019-03-08 | 网宿科技股份有限公司 | 基于移动应用的数据传输加速方法、相关设备和加速系统 |
CN110245262A (zh) * | 2019-05-20 | 2019-09-17 | 平安银行股份有限公司 | 影像文件处理方法和装置 |
CN112667579B (zh) * | 2020-12-30 | 2023-07-28 | 杭州趣链科技有限公司 | 文件存储方法、装置、设备和存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102833337A (zh) * | 2012-08-30 | 2012-12-19 | 北京星网锐捷网络技术有限公司 | 一种ftp文件上传、下载方法及装置 |
CN103020241A (zh) * | 2012-12-18 | 2013-04-03 | 网宿科技股份有限公司 | 基于会话的动态页面缓存方法和系统 |
CN103036977A (zh) * | 2012-12-13 | 2013-04-10 | 北京奇虎科技有限公司 | 基于内容分发网络的业务推送方法及推送系统 |
CN103139236A (zh) * | 2011-11-23 | 2013-06-05 | 华为技术有限公司 | 一种元数据的处理方法、装置及cdn互通系统 |
-
2013
- 2013-08-19 CN CN201310362191.1A patent/CN103401946B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103139236A (zh) * | 2011-11-23 | 2013-06-05 | 华为技术有限公司 | 一种元数据的处理方法、装置及cdn互通系统 |
CN102833337A (zh) * | 2012-08-30 | 2012-12-19 | 北京星网锐捷网络技术有限公司 | 一种ftp文件上传、下载方法及装置 |
CN103036977A (zh) * | 2012-12-13 | 2013-04-10 | 北京奇虎科技有限公司 | 基于内容分发网络的业务推送方法及推送系统 |
CN103020241A (zh) * | 2012-12-18 | 2013-04-03 | 网宿科技股份有限公司 | 基于会话的动态页面缓存方法和系统 |
Also Published As
Publication number | Publication date |
---|---|
CN103401946A (zh) | 2013-11-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN103401946B (zh) | Http上传加速方法和系统 | |
US10411956B2 (en) | Enabling planned upgrade/downgrade of network devices without impacting network sessions | |
US10587544B2 (en) | Message processing method, processing server, terminal, and storage medium | |
EP3907973A1 (en) | Method for establishing communication connection and proxy server | |
WO2017088384A1 (zh) | 一种直播视频的上传方法、装置及系统 | |
US8069251B2 (en) | System and/or method for client-driven server load distribution | |
US10645145B2 (en) | Method and apparatus for accelerating data transmission in a network communication system | |
TWI535255B (zh) | 一種發送業務請求訊息的方法及裝置 | |
CN105103522A (zh) | 穿过客户端侧nat防火墙的基于udp的传输协议的低时延服务器侧重定向 | |
US10021182B2 (en) | Method and apparatus for data synchronization | |
EP2930899A1 (en) | Tcp link configuration method, apparatus and device | |
EP3011724A1 (en) | Context management | |
WO2018107387A1 (zh) | 数据传输方法、装置、系统、电子设备及计算机程序产品 | |
CN104009938A (zh) | 基于路由层面的长连接的方法和系统 | |
CN103108037B (zh) | 一种通信方法,Web服务器及Web通信系统 | |
WO2012064856A3 (en) | Methods for reducing latency in network connections and systems thereof | |
CN103813181A (zh) | 一种视频优化系统及方法 | |
CN103997479B (zh) | 一种非对称服务ip代理方法和设备 | |
CN107995233B (zh) | 建立连接的方法及相应的设备 | |
WO2016086755A1 (zh) | 一种报文处理的方法和透明代理服务器 | |
WO2017080386A1 (zh) | 一种报文处理方法和装置 | |
US20150006622A1 (en) | Web contents transmission method and apparatus | |
US8650313B2 (en) | Endpoint discriminator in network transport protocol startup packets | |
CN104780230A (zh) | 自动获取云服务器ip地址的方法、系统和云系统 | |
US20130024543A1 (en) | Methods for generating multiple responses to a single request message and devices thereof |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant |