redirect_to | layout | title | description | pid | top_nav_section | nav_section |
---|---|---|---|---|---|---|
/overview/analytics.html |
page_v2 |
Analytics with GA |
Prebid.js Analytics with GA |
30 |
dev_docs |
reference |
{: .no_toc}
- TOC {:toc }
{% highlight js %}
// If you're using GA, this should already be in your page: (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');
// Add the below code snippet to your page pbjs.que.push(function() { pbjs.enableAnalytics({ provider: 'ga', options: { global: 'ga', // name of GA global. Default is 'ga' enableDistribution: false, } }); });
{% endhighlight %}
- This code snippet has to be inserted after the
'ga'
param is available. - This code snippet has to be inserted after pbjs.que has been defined.
- You must include
"ga"
in the"analytics"
array inpackage.json
.
Note: we recommend disabling enableDistribution
if you are using more than 4 bidders. This is because GA throttles the number of events that can be logged (20 initial + 2/second). Distribution data provides you with a histogram of CPM distribution and bid load time (latency) for each bidder. See distribution data demo here.
See this link for details on GA's throttling.
To track a lower volume of traffic in Google Analytics, you may specify a sample rate in the options. For example, to set up a 5% sample rate:
{% highlight js %} pbjs.que.push(function() { pbjs.enableAnalytics({ provider: 'ga', options: { global: 'ga' enableDistribution: false, sampling: 0.05 } }); }); {% endhighlight %}
At the start of each page, Prebid chooses a random number between 0 and 1 and logs the analytics only if the number is less than the supplied sample rate, which defaults to 1 (100%). Of course a smaller sample rate means that reported numbers will be correspondingly lower, so a scaling factor in reports may be useful, but is outside the scope of Prebid.
It should also be noted that all events on a given page are subject to the same analytics behavior. This means that all requests, responses, and renders on a page are either logged or not logged.
Prebid.js sends out GA-compatible Events. (For more information, see the GA docs on Event Tracking).
In this example, the page has 1 ad unit with 3 bidders. The timeout is set to 400ms. Let's go through what Prebid Analytics sends out to GA:
{: .table .table-bordered .table-striped }
Time | What Happened | GA Events Sent |
---|---|---|
15ms | Prebid.js sends out bid requests to bidders AppNexus, OpenX, and Pubmatic. | Event 1: Category=Prebid.js Bids , Action=Requests , Label=appnexus , Value=1.Event 2: Category= Prebid.js Bids , Action=Requests , Label=openx , Value=1.Event 3: Category= Prebid.js Bids , Action=Requests , Label=pubmatic , Value=1 |
203ms | AppNexus' bid came back with a CPM of $2.314 and a latency of 188ms. | Event 1: Category=Prebid.js Bids , Action=Bids , Label=appnexus , Value=231.Event 2: Category= Prebid.js Bids , Action=Bid Load Time , Label=appnexus , Value=188 |
274ms | Pubmatic's bid came back with a CPM of $0 and a latency of 259ms. | No bid event sent out because it is a no bid. Event 1: Category= Prebid.js Bids , Action=Bid Load Time , Label=appnexus , Value=259 |
415ms | Timeout is up because 400ms has passed since bid requests were sent. OpenX has timed out. | Event 1: Category=Prebid.js Bids , Action=Timeouts , Label=openx , Value=1 |
476ms | OpenX's bid came back with a CPM of $2.831 and a latency of 461ms (a bid may still come back after a timeout). | Event 1: Category=Prebid.js Bids , Action=Bids , Label=openx , Value=283. Event 2: Category= Prebid.js Bids , Action=Bid Load Time , Label=openx , Value=461 |
572ms | Google Ad Manager completed its auction and the AppNexus $2.314 bid won. | Event 3: Category=Prebid.js Bids , Action=Wins , Label=appnexus , Value=231 |
Note that a Win event is a true win, meaning that it is not just the highest bid in the header bidding auction, but the winning bid across the entire auction hosted by the ad server and its creative is served back to the page.
After you've implemented the above code snippet, load the page a few times, wait 1-2 hours for GA's data pipeline to finish, and go to your GA Reporting screen. Navigate to Behavior > Events. You should be able to find the Prebid.js events (if you have many other events, filter Event Category by Prebid.js
)
GA Category:
data:image/s3,"s3://crabby-images/d27cd/d27cd524999bcec7309a043720cec28c6f3ccbae" alt="Prebid Diagram Image"
GA Action:
data:image/s3,"s3://crabby-images/34f42/34f42e4f2081762c668ce11e8e64cd82ee723df4" alt="Prebid Diagram Image"
GA Label:
data:image/s3,"s3://crabby-images/b1561/b15616f6e7cf84f2d9c4c3a61ea2bee90b3bcf96" alt="Prebid Diagram Image"
As you can see, this reporting screen cannot help you answer questions such as:
- What's the AppNexus bidder's avg. bid CPM
- What's the AppNexus bidder's avg. bid load time?
To see how to answer these questions, see the following sections.
With a custom report in GA, you can get:
data:image/s3,"s3://crabby-images/ecded/ecdedf54df96b1654a91818fe0ba9c12bfb47d88" alt="Prebid Diagram Image"
This can be built by:
data:image/s3,"s3://crabby-images/7b033/7b033e51fd8efa50dc2a91bed39e0a4a71c876ba" alt="Prebid Diagram Image"
However, this is still not the most ideal dashboard, because it's hard to find information you need quickly. For that you can build a Spreadsheet Dashboard as shown in the next section.
Find the demo of the Spreadsheet Dashboard here.
To build your own version of this report dashboard:
Install the Google Analytics Spreadsheet Add-on. Understand how the add-on works.
Make a local copy of the Demo Dashboard.
data:image/s3,"s3://crabby-images/494fe/494feb924d8fba3de69d0afd58b3167ecf819570" alt="Prebid Diagram Image"{: .pb-lg-img :}
In your local copy, go to the Report Configuration tab, update the GA profile ID (you should be able to get this ID from Step 1)
data:image/s3,"s3://crabby-images/954e3/954e34975cad568b8ede2e2a6a383a72bbd78df2" alt="Prebid Diagram Image"{: .pb-lg-img :}
data:image/s3,"s3://crabby-images/63ede/63ede56537ec84892517670d584081e0cd8a5eba" alt="Prebid Diagram Image"{: .pb-lg-img :}
data:image/s3,"s3://crabby-images/ce742/ce742dedcfece0c4ef7c49190fd0969b7c7d45f9" alt="Prebid Diagram Image"{: .pb-lg-img :}