PageSpeed Insights 因为 Google Analytics 得分 99/100 (满分 100,得分 99)- 我应该如何缓存GA ?

我正在追求网页速度能达到满分,现在几乎快达到了,我试图找到一个很好的解决方案来缓存谷歌分析(GA)。

这是我得到的信息:

利用浏览器缓存 在静态资源的HTTP报头中设置过期日期或最大年龄指示浏览器从本地磁盘加载以前下载的资源,而不是通过网络。 利用浏览器缓存以下可缓存资源: http://www.google-analytics.com/analytics.js (2 hours)

我找到的唯一解决方案是2012年的,我不认为这是一个好的解决方案。本质上,您复制GA代码并自己托管它。然后运行cron作业,每天重新检查谷歌一次,以获取最新的GA代码并替换它。

http://diywpblog.com/leverage-browser-cache-optimize-google-analytics/

我还能做什么来达到100/100,同时也使用谷歌分析?

谢谢你!

165432 次浏览

您可以尝试在本地托管analysis .js,并使用缓存脚本或手动更新它的内容。

js文件每年只更新几次,如果你不需要任何新的跟踪功能,就手动更新它。

https://developers.google.com/analytics/devguides/collection/analyticsjs/changelog

谷歌注意事项反对使用分析脚本的本地副本。 然而,如果你正在这样做,你可能会想要使用本地副本的插件&

.调试脚本

第二个具有积极缓存的关注是,您将从缓存的页面获得点击-这些页面可能已经更改或已从站点中删除。

store local analysis .js,但谷歌不建议这样做: https://support.google.com/analytics/answer/1032389?hl=en < / p >

不建议,因为谷歌可以在他们想要的时候更新脚本,所以只要做一个脚本,每周下载分析javascript,你就不会有麻烦!

顺便说一下,这个解决方案防止adblock从阻塞谷歌分析脚本

我不会担心的。不要把它放在你自己的服务器上,听起来这是谷歌的一个问题,但它得到的很好。将文件放在您自己的服务器上将产生许多新问题。

他们可能需要每次都调用该文件,而不是从客户端的缓存中获取,因为这样就不会计算访问次数。

如果你觉得有问题,可以在谷歌insights上运行谷歌insights URL,笑一笑,放松一下,继续你的工作。

你可以使用以下方法缩小page中的所有脚本,包括analytics.js:

记得在使用它之前缩小文件。否则将消耗更多的处理时间。

要修复此问题,您必须在本地下载文件并运行cron作业以保持更新。注意:这不会让你的网站更快,所以最好忽略它。

但是,为了演示目的,请遵循以下指南: http://diywpblog.com/leverage-browser-cache-optimize-google-analytics/ < / p >

谷歌Analytics js库中有一个名为ga-lite的子集,你可以根据自己的需要进行缓存。

该库使用谷歌Analytics的公共REST API将用户跟踪数据发送到谷歌。你可以从关于ga-lite的博文读到更多。

免责声明:我是这个库的作者。我为这个特定的问题而挣扎,我发现最好的结果就是实现这个解决方案。

在谷歌文档中,他们已经确定了一个pagespeed过滤器,它将异步加载脚本:

ModPagespeedEnableFilters make_google_analytics_async

你可以在这里找到文档:https://developers.google.com/speed/pagespeed/module/filter-make-google-analytics-async

需要强调的一点是,过滤器被认为是高风险的。从文档中可以看出:

make_google_analytics_async过滤器是实验性的,还没有经过广泛的实际测试。重写会导致错误的一种情况是,如果过滤器错过了对返回值的谷歌Analytics方法的调用。如果找到这样的方法,重写将被跳过。但是,如果取消资格的方法在加载之前出现,在诸如“onclick”之类的属性中,或者在外部资源中,则会错过它们。这些病例预计是罕见的。

如果谷歌欺骗了你,你也可以欺骗谷歌:

这是pageSpeed的用户代理:

“Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/536.8 (KHTML, like Gecko; Google Page Speed Insights) Chrome/19.0.1084.36 Safari/536.8”

你可以插入一个条件来避免为PageSpeed提供分析脚本:

<?php if (!isset($_SERVER['HTTP_USER_AGENT']) || stripos($_SERVER['HTTP_USER_AGENT'], 'Speed Insights') === false): ?>
// your analytics code here
<?php endif; ?>

显然,这不会带来任何真正的改善,但如果你唯一关心的是获得100/100的分数,这就可以了。

您可以通过自己的服务器代理谷歌分析脚本,将其保存在本地,并每小时自动更新文件,以确保它始终是谷歌的最新版本。

我已经在几个网站上做了这个,现在一切都很好。

谷歌NodeJS / MEAN Stack中的分析代理路由

这就是我在用MEAN堆栈构建的我的博客上实现它的方式。

router.get('/analytics.js', function (req, res, next) {
var fileUrl = 'http://www.google-analytics.com/analytics.js';
var filePath = path.resolve('/content/analytics.js');


// ensure file exists and is less than 1 hour old
fs.stat(filePath, function (err, stats) {
if (err) {
// file doesn't exist so download and create it
updateFileAndReturn();
} else {
// file exists so ensure it's not stale
if (moment().diff(stats.mtime, 'minutes') > 60) {
updateFileAndReturn();
} else {
returnFile();
}
}
});


// update file from remote url then send to client
function updateFileAndReturn() {
request(fileUrl, function (error, response, body) {
fs.writeFileSync(filePath, body);
returnFile();
});
}


// send file to client
function returnFile() {
res.set('Cache-Control', 'public, max-age=' + oneWeekSeconds);
res.sendFile(filePath);
}
});

谷歌分析代理动作方法在ASP。NET MVC

这就是我如何在其他用ASP构建的网站上实现它的。净MVC。

public class ProxyController : BaseController
{
[Compress]
public ActionResult GoogleAnalytics()
{
var fileUrl = "https://ssl.google-analytics.com/ga.js";
var filePath = Server.MapPath("~/scripts/analytics.js");


// ensure file exists
if (!System.IO.File.Exists(filePath))
UpdateFile(fileUrl, filePath);


// ensure file is less than 1 hour old
var lastModified = System.IO.File.GetLastWriteTime(filePath);
if((DateTime.Now - lastModified).TotalMinutes > 60)
UpdateFile(fileUrl, filePath);


// enable caching for 1 week for page speed score
Response.AddHeader("Cache-Control", "max-age=604800");


return JavaScript(System.IO.File.ReadAllText(filePath));
}


private void UpdateFile(string fileUrl, string filePath)
{
using (var response = WebRequest.Create(fileUrl).GetResponse())
using (var dataStream = response.GetResponseStream())
using (var reader = new StreamReader(dataStream))
{
var body = reader.ReadToEnd();
System.IO.File.WriteAllText(filePath, body);
}
}
}

这是MVC ProxyController用于Gzip压缩的CompressAttribute

public class CompressAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{


var encodingsAccepted = filterContext.HttpContext.Request.Headers["Accept-Encoding"];
if (string.IsNullOrEmpty(encodingsAccepted)) return;


encodingsAccepted = encodingsAccepted.ToLowerInvariant();
var response = filterContext.HttpContext.Response;


if (encodingsAccepted.Contains("gzip"))
{
response.AppendHeader("Content-encoding", "gzip");
response.Filter = new GZipStream(response.Filter, CompressionMode.Compress);
}
else if (encodingsAccepted.Contains("deflate"))
{
response.AppendHeader("Content-encoding", "deflate");
response.Filter = new DeflateStream(response.Filter, CompressionMode.Compress);
}
}
}

更新谷歌分析脚本

在客户端,我将分析路径与当前日期附加到小时,这样浏览器就不会使用超过一小时前的缓存版本。

<!-- analytics -->
<script>
(function (i, s, o, g, r, a, m) {
i['GoogleAnalyticsObject'] = r; i[r] = i[r] || function () {
(i[r].q = i[r].q || []).push(arguments)
}, i[r].l = 1 * new Date(); a = s.createElement(o),
m = s.getElementsByTagName(o)[0]; a.async = 1; a.src = g; m.parentNode.insertBefore(a, m)
})(window, document, 'script', '/analytics.js?d=' + new Date().toISOString().slice(0, 13), 'ga');
</script>

varvy.com (100/100谷歌页面速度洞察)只在用户滚动页面时加载谷歌分析代码:

var fired = false;


window.addEventListener("scroll", function(){
if ((document.documentElement.scrollTop != 0 && fired === false) || (document.body.scrollTop != 0 && fired === false)) {


(function(i,s,o,g,r,a,m{i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)})(window,document,'script','//www.google-analytics.com/analytics.js','ga');


ga('create', 'UA-XXXXXXXX-X', 'auto');
ga('send', 'pageview');


fired = true;
}
}, true);

试一下这只是插入之前

<script async='async' src='https://cdn.jsdelivr.net/ga-lite/latest/ga-lite.min.js'></script> <script>var galite=galite||{};galite.UA="xx-xxxxxxx-x";</script>

请将xx-xxxxxxx-x更改为您的代码,请检查到这里的实现http://www.gee.web.id/2016/11/how-to-leverage-browser-caching-for-google-analitycs.html

下面是一个使用JS的非常简单的解决方案,用于基本的GA跟踪,也适用于边缘缓存/代理(这是从注释转换过来的):

if(navigator.userAgent.indexOf("Speed Insights") == -1) {
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');


ga('create', 'UA-XXXXXXXXX-X', 'auto');
ga('send', 'pageview');
}

注:这是默认的GA脚本。你可能还有其他ga()调用,如果是这样,你需要在调用ga()之前总是检查用户代理,否则它可能会出错。

这可能会奏效:)

<script>
$.ajax({
type: "GET",
url: "https://www.google-analytics.com/analytics.js",
success: function(){},
dataType: "script",
cache: true
});
</script>

Nginx的:

location ~ /analytics.js {
proxy_pass https://www.google-analytics.com;
expires 31536000s;
proxy_set_header Pragma "public";
proxy_set_header Cache-Control "max-age=31536000, public";
}

然后将路径https://www.google-analytics.com/analytics.js改为https://yoursite.com/analytics.js

PHP

在你的HTML或PHP代码中添加这个:

<?php if (!isset($_SERVER['HTTP_USER_AGENT']) || stripos($_SERVER['HTTP_USER_AGENT'], 'Speed Insights') === false): ?>
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');


ga('create', 'UA-PUT YOUR GOOGLE ANALYTICS ID HERE', 'auto');
ga('send', 'pageview');
</script>
<?php endif; ?>

JavaScript

这在JavaScript中工作得很好:

  <script>
if(navigator.userAgent.indexOf("Speed Insights") == -1) {
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');


ga('create', 'UA-<PUT YOUR GOOGLE ANALYTICS ID HERE>', 'auto');
ga('send', 'pageview');
}
</script>

NiloVelez已经说过:显然,它不会有任何真正的改善,但如果你唯一关心的是得到100/100的分数,这可以做到。

根据你对谷歌Analytics数据的使用,如果你想要基本信息(比如访问量、UI交互),你可能根本不需要包含Analytics .js,但仍然可以在GA中收集数据。

一种选择可能是在缓存脚本中使用测量协议。 谷歌分析:测量协议概述 < / p >

当您显式地将传输方法设置为image时,您可以看到GA如何构造自己的图像信标。

ga('set', 'transport', 'image');


https://www.google-analytics.com/r/collect
?v={protocol-version}
&tid={tracking-id}
&cid={client-id}
&t={hit-type}
&dl={location}

您可以使用所需的有效负载创建自己的GET或POST请求。

但是,如果你需要更详细的内容,那就不值得你这么做了。

您可以设置一个将www.google-analytics.com作为其源服务器的cloudfront发行版,并在cloudfront发行版设置中设置一个较长的过期报头。然后在谷歌片段中修改该域。这可以防止在您自己的服务器上加载,也可以避免在cron作业中不断更新文件。

这是设置&忘记。所以你可能想要添加一个账单警报到cloudfront,以防有人“复制”你的代码片段并窃取你的带宽;-)

编辑:我试过了,它不是那么容易,Cloudfront通过缓存控制头没有简单的方法来删除它

在新选项卡中打开https://www.google-analytics.com/analytics.js文件,复制所有代码。

现在在你的网页目录中创建一个文件夹,重命名为google-analytics。

在同一个文件夹中创建一个文本文件,并粘贴上面复制的所有代码。

将文件重命名为ga-local.js

现在更改URL,在谷歌分析代码中调用本地托管的分析脚本文件。它看起来像这样,即https://domain.xyz/google-analytics/ga.js

最后,把你的新谷歌分析代码放在你的网页的页脚。

你可以出发了。现在检查你的谷歌PageSpeed Insights网站。它将不会显示杠杆浏览器缓存谷歌分析的警告。这个解决方案的唯一问题是,定期手动更新分析脚本。

2020年,Page Speed Insights用户代理为:移动端“Chrome-Lighthouse”和桌面端“谷歌Page Speed Insights”。

<?php if (!isset($_SERVER['HTTP_USER_AGENT']) || stripos($_SERVER['HTTP_USER_AGENT'], 'Chrome-Lighthouse') === false  || stripos($_SERVER['HTTP_USER_AGENT'], 'Google Page Speed Insights') === false): ?>
// your google analytics code and other external script you want to hide from PageSpeed Insights here
<?php endif; ?>