[发明专利]一种提高页面加载速度的方法及系统有效
申请号: | 201510015200.9 | 申请日: | 2015-01-12 |
公开(公告)号: | CN104573025B | 公开(公告)日: | 2018-09-04 |
发明(设计)人: | 雷宁 | 申请(专利权)人: | 北京京东尚科信息技术有限公司;北京京东世纪贸易有限公司 |
主分类号: | G06F17/30 | 分类号: | G06F17/30 |
代理公司: | 北京品源专利代理有限公司 11332 | 代理人: | 路凯;胡彬 |
地址: | 100080 北京市海淀区杏石口路6*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 提高 页面 加载 速度 方法 系统 | ||
本发明实施例公开了一种提高页面加载速度的方法及系统,所述方法包括:内容分发网络接收浏览器发送的页面框架请求,向服务器发起页面框架请求;服务器依据页面框架请求,渲染页面框架,将渲染后的页面框架通过内容分发网络发送至浏览器;浏览器解析渲染后的页面框架,以获得页面模块标识,并通过内容分发网络向服务器发起包含页面模块标识的页面模块请求;服务器依据页面模块请求,渲染页面模块,将渲染后的页面模块发送至内容分发网络;内容分发网络依据页面模块标识,将渲染后的页面模块填充到渲染后的页面框架中形成页面,将页面发送至浏览器。通过本发明实施例公开的方法及系统,实现了对页面框架和页面模块的异步渲染,提高了网页加载速度。
技术领域
本发明实施例涉及互联网技术领域,尤其涉及一种提高页面加载速度的方法及系统。
背景技术
当前的网络环境中,用户访问的HTML(HyperText Mark-up Language,超文本标记语言)页面可能在长时间内没有变化,因此可以使用页面静态化技术处理页面,提高网页加载的速度。
页面静态化技术是将应用服务器动态渲染后的页面缓存到Web(互联网)服务器的硬盘上,当用户请求访问页面时,直接读取硬盘中缓存的页面,不需要再经过应用服务器渲染。
目前,基于页面静态化技术,用户访问页面的主要过程如图1所示:
步骤S101,CDN(Content Delivery Network,内容分发网络)集群接收用户发送的访问页面请求;
步骤S102,CDN集群判断是否缓存有与访问页面请求相对应的页面;若有,则执行步骤S108;若无,则执行步骤S103;
步骤S103,CDN集群将访问页面请求转发到Web服务器;
步骤S104,Web服务器接收访问页面请求,判断硬盘中是否缓存有与访问页面请求相对应的页面;若有,则执行步骤S108;若无,则执行步骤S105;
步骤S105,Web服务器将访问页面请求转发给应用服务器,应用服务器对与访问页面请求相对应的页面进行多线程渲染,向Web服务器返回渲染后的页面;
步骤S106,Web服务器将渲染后的页面缓存到硬盘,并将渲染后的页面发送至CDN集群;
步骤S107,CDN集群接收渲染后的页面,并缓存;
步骤S108,CDN集群返回渲染后的页面至浏览器,浏览器解析渲染后的页面。
其中,目前应用服务器是通过线程池进行对整个页面进行渲染,但是访问页面请求量超过线程池最大值时,没有分配到线程资源的渲染任务会阻塞,造成页面不能加载或者加载时间超时,用户体验极差。
发明内容
本发明实施例提供一种提高页面加载速度的方法及系统,以实现对页面框架和页面模块进行异步渲染,降低了页面的加载时间。
一方面,本发明实施例提供了一种提高页面加载速度的方法,包括:
内容分发网络接收浏览器发送的页面框架请求,向服务器发起页面框架请求;
所述服务器依据所述页面框架请求,渲染页面框架,将渲染后的页面框架通过所述内容分发网络发送至所述浏览器;
所述浏览器解析所述渲染后的页面框架,以获得页面模块标识,并通过所述内容分发网络向所述服务器发起包含所述页面模块标识的页面模块请求;
所述服务器依据所述页面模块请求,渲染页面模块,将渲染后的页面模块发送至所述内容分发网络;
所述内容分发网络依据所述页面模块标识,将渲染后的页面模块填充到所述渲染后的页面框架中形成页面,将所述页面发送至所述浏览器。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京京东尚科信息技术有限公司;北京京东世纪贸易有限公司,未经北京京东尚科信息技术有限公司;北京京东世纪贸易有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201510015200.9/2.html,转载请声明来源钻瓜专利网。
- 上一篇:信息搜索方法、信息搜索装置和终端
- 下一篇:社区网格信息处理方法和系统