使用Google CDN导致网站页面无法加载的问题解决

所属分类: 网站运营 / 建站经验 阅读数: 98
收藏 0 赞 0 分享

国内网非常多的网站都使用免费的 Google CDN 服务来加载某些 js、字体样式库以提升网页浏览体验,例如 jQuery、Google Fonts。但是目前 Google 的大多数网站在大陆无法正常访问,因此这些本身是加快网页载入的库反而成为了阻塞网站加载的原因。这种情况国内的网站并不多,但是国外的网站却非常多地使用这些库。一般地,当 Google CDN 库称为网页加载的限制因素时,浏览器状态条会显示状态为 “正在等待 ajax.googleapis.com 的响应...” 或 “正在连接...” 等字样。
20165494100327.png (500×325)

如果打开控制台,能看见 Google CDN 确实正在阻塞网页加载。如果等待足够长的时间,浏览器最终会放弃加载,并呈现一个残缺的网页,这并不好。下面从网页开发者、浏览器用户的角度给出一些解决方案。
对于网页开发者:选用其它 CDN 库

网页开发者必须考虑到这个问题,因此在设计网站时就应该考虑弃用 Google CDN 库。如果访者大多来自国内,可以考虑使用百度 CDN、新浪 CDN 库,它们都包含了非常常用的 JS 库文件。如果有面向国际的访客,则可以考虑使用微软的 ASP.NET CDN。

例如以下是使用微软 CDN 加载 jQuery 的一个范例:

JavaScript Code复制内容到剪贴板
  1. <script src="http://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.8.2.min.js" type="text/javascript"></script>   

如果要使用 Google Fonts,则可以使用 360 提供的代理 CDN。这样一来,即时要使用 Google Fonts 网页字体,网页的速度也不会受到干扰和阻塞。

修改 hosts

对于用户,我们无法直接令浏览的网页弃用其正在使用的 Google CDN,从而出现无法加载的情况,那应该怎么办呢?解决方案之一就是修改 hosts。通过修改 hosts,强迫 CDN 域名指向指定的 IP,得以成功从 Google 加载这些文件。

值的一提的是,有一部分 Google CDN,例如 fonts.googleapis.com、fonts.gstatic.com,它们可以被解析到首都的 IP 地址,因此如果在 DNS 解析失效的情况下,通过 hosts 将这些域名直接指向首都的 IP 是最好、最快速的。

当然,如果 Google 改变心意,首都的服务器拒绝提供这些域名的缓存服务的话,就没有办法了。至于为什么 Google 不索性把所有的 CDN 都解析到首都,也没人清楚。
20165494125670.jpg (500×388)

修改 hosts 并不一定是好方法,因为速度可能会比较缓慢,另 hosts 可能失效。

使用 Chrome 扩展主动替换为国内 CDN

国内的一些服务器通过镜像或同步拷贝等一些方法能保留一份与 Google CDN 同样的文件专供国内用户加载。我们可以使用一款名叫 Replace Google CDN 的 Chrome 扩展插件,来主动替换浏览的网页里的 Google CDN 为国内的替代服务器。

这款插件作者为 @justjavac,Github 项目地址为 github.com/justjavac/ReplaceGoogleCDN,扩展地址为 https://chrome.google.com/webstore/detail/replace-google-cdn/kpampjmfiopfpkkepbllemkibefkiice。当然你可能需要先使用一些技巧来打开这个应用商店才能安装。

扩展插件支持替换 Google CDN 为中国科技大学提供的 CDN,支持 ajax/fonts.googleapis.com、themes.googleusercontent.com 的替换,并且支持 HTTPS。在这里要感谢他们。
20165494147137.jpg (500×255)

安装好这款插件后,浏览任何带有 Google CDN 的网页时都会被跳转到这个节点,这样就不会出现阻塞的情况了。

更多精彩内容其他人还在看

SEO实战:网站被黑有何影响? 如何处理网站被黑?

网站被黑是常见的事情,尤其是一些商业类型的网站,网站被黑有的是被竞争对手恶意报复,有的是被博彩,赌博等违法网站挂黑链。网站被黑会有什么影响呢?网站被黑后该怎么办呢?本文将提供相关措施供大家了解
收藏 0 赞 0 分享

当当网的内部框架开源策略案例分享

这篇文章主要介绍了当当网的内部框架开源策略案例分享,包括其Dubbo项目和分布式作业调度框架elastic-job的开源情况简介,需要的朋友可以参考下
收藏 0 赞 0 分享

当当网海量信息的组织与发布经验分享

这篇文章主要介绍了当当网海量信息的组织与发布经验分享,包括双11时促销系统与交易系统的一些重构实践,需要的朋友可以参考下
收藏 0 赞 0 分享

四种自助建站排版技术有什么优缺点?优劣对比分析

四种自助建站排版技术有什么优缺点?很多朋友都不是很清楚,所以今天小编就为大家分析这四种自助建站排版技术,一起来看看吧
收藏 0 赞 0 分享

如何注册网站 新人注册网站图文步骤

由于目前所见即所得类型的工具越来越多,使用也越来越方便,所以网站制作已经变成了一件轻松的工作,不像以前要手工编写一行行的源代码那样
收藏 0 赞 0 分享

浅析豆瓣网站运营的主要技术模式

这篇文章主要介绍了豆瓣网站运营的主要技术模式,作为国内以Python驱动的知名网站之一,本文介绍了豆瓣的一些技术理念,需要的朋友可以参考下
收藏 0 赞 0 分享

深入分析京东云数据库的运营模式

这篇文章主要介绍了京东云数据库的运营模式,京东利用服务器集群的方式构建起了大型的基于云的数据存储方式,需要的朋友可以参考下
收藏 0 赞 0 分享

剖析美团的以Python为主导的云平台发展战略

这篇文章主要介绍了美团的以Python为主导的云计算发展战略,美团对于Python的Django和Tornado框架的应用着实令人眼前一亮,是为国内Python技术的一大主要推动力量,需要的朋友可以参考下
收藏 0 赞 0 分享

浅谈如何提高网站内页权重

近期发现手上优化的网站收录量还好,收录率达到40%以上,但是就是没排名,分析了下作了相应调整,后续优化效果将相继文章分享出
收藏 0 赞 0 分享

搜狐云发展中DomeOS的开发与Docker的应用

这篇文章主要介绍了搜狐云发展中DomeOS的开发与Docker的应用,DomeOS是搜狐自助研发的企业级业务编排运维管理系统,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多