开发者

Google Analytics API Authentication Speedup

I'm using a Google Analytics API Class in PHP made by Doug Tan to retrieve Analytics data from a specific profile.

Check the url he开发者_如何学运维re: http://code.google.com/intl/nl/apis/analytics/docs/gdata/gdataArticlesCode.html

When you create a new instance of the class you can add the profile id, your google account + password, a daterange and whatever dimensions and metrics you want to pick up from analytics.

For example i want to see how many people visited my website from different country's in 2009.

//make a new instance from the class
$ga = new GoogleAnalytics($email,$password);

//website profile example id
$ga->setProfile('ga:4329539');

//date range
$ga->setDateRange('2010-02-01','2010-03-08');

//array to receive data from metrics and dimensions
$array = $ga->getReport(
        array('dimensions'=>('ga:country'),
        'metrics'=>('ga:visits'),
        'sort'=>'-ga:visits'
        )
);

Now you know how this API class works, i'd like to adress my problem.

Speed. It takes alot of time to retrieve multiple types of data from the analytics database, especially if you're building different arrays with different metrics/dimensions. How can i speed up this process?

Is it possible to store all the possible data in a cache so i am able to retrieve the data without loading it over and over again?


You can load the data in a cache sure, precisely how/where the data is cached is entirely up to you. You can use anything from per-request caching (which will be pretty useless for this particular problem) to things like APC, memcached, a local database or even just saving the raw results to files. These will not make the actual retrieval of the data from Google any quicker of course.

On that note, it is likely (not having seen the code) that the requests over to Google are probably being executed sequentially. It is likely possible to extend the PHP class to allow requesting multiple sets of data from Google in parallel (e.g. with cURL Multi).


Faced the same problem and decided to use a cronjob and save the data in a .json file I can use for the display.

        $globalTrendData = $client->runReport([
            'property' => 'properties/' . $property_id,
            'dateRanges' => [
                new DateRange([
                    'start_date' => '20daysAgo',
                    'end_date' => 'yesterday',
                ]),
            ],
            'dimensions' => [
                new Dimension(['name' => 'pagePath',]),
                new Dimension(['name' => 'pageTitle',]),
                new Dimension(['name' => 'city',]),
                new Dimension(['name' => 'sessionSource',]),
                new Dimension(['name' => 'date',])
            ],
            'metrics' => [
                new Metric(['name' => 'screenPageViews',]),
                new Metric(['name' => 'userEngagementDuration',]),
                new Metric(['name' => 'activeUsers',]),

            ]
        ]);
        
foreach ($globalTrendData->getRows() as $key => $row) {

            $saved['globalTrendData'][$key]['dimension']['pagePath'] = (array) $row->getDimensionValues()[0]->getValue() ;
            $saved['globalTrendData'][$key]['dimension']['pageTitle'] = (array) $row->getDimensionValues()[1]->getValue() ;
            $saved['globalTrendData'][$key]['dimension']['city'] = (array) $row->getDimensionValues()[2]->getValue() ;
            $saved['globalTrendData'][$key]['dimension']['source'] = (array) $row->getDimensionValues()[3]->getValue() ;
            $saved['globalTrendData'][$key]['dimension']['date'] = (array) $row->getDimensionValues()[4]->getValue() ;


            $saved['globalTrendData'][$key]['metric']['screenPageViews'] = (array) $row->getMetricValues()[0]->getValue() ;
            $saved['globalTrendData'][$key]['metric']['userEngagementDuration'] = (array) $row->getMetricValues()[1]->getValue() ;
            $saved['globalTrendData'][$key]['metric']['activeUsers'] = (array) $row->getMetricValues()[2]->getValue() ;

        }

      file_put_contents($GLOBALS['serverPath'].'/monitoring/statistics.json',json_encode($saved, JSON_PRETTY_PRINT)) ;

Json file output exemple :

"globalTrendData": {
    "0": {
        "dimension": {
            "pagePath": {
                "0": "\/modeles-maison\/liste"
            },
            "pageTitle": {
                "0": "Plans de maisons 100% personnalisables - adapt\u00e9s \u00e0 votre style et \u00e0 votre budget"
            },
            "city": {
                "0": "(not set)"
            },
            "source": {
                "0": "(direct)"
            },
            "date": {
                "0": "20220128"
            }
        },
        "metric": {
            "screenPageViews": {
                "0": "18"
            },
            "userEngagementDuration": {
                "0": "152"
            },
            "activeUsers": {
                "0": "1"
            }
        }
    }
}
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜