apm-agent-rum-js
apm-agent-rum-js copied to clipboard
First paint of page
We want to collect the first paint of page,but how to calculate it
Hi @741439599,
Thanks for using the RUM agent!
The agent calculates First Contentful Paint automatically so you don't need to do it manually. Just make sure that you are not disabling the instrumentation related to page-load
The agent will attach FCP to the transaction created while the page is loading. This transaction is commonly known as "page-load transaction". You can see all the data attached via APM UI.
data:image/s3,"s3://crabby-images/2c53e/2c53e17f042b1861b72ae701e7c37da3cc8e21e5" alt="Screenshot 2022-07-26 at 11 02 10"
You also can look for its info in Kibana discover:
data:image/s3,"s3://crabby-images/3f9b7/3f9b7a0e722cc4d2e03a0daf2d2be6e7a2c345ee" alt="Screenshot 2022-07-26 at 11 06 06"
Apart from that, on the User Experience page you can see all key user experience metrics, too.
Thanks, Alberto
Thanks,I add below code in captureObserverEntries function of metrics.js
const fpEntry = list.getEntriesByName(FIRST_PAINT)[0]
if (fpEntry) {
const fp = parseInt(
unloadDiff >= 0 ? fpEntry.startTime - unloadDiff : fpEntry.startTime
)
result.marks.firstPaint = fp
}
Hi @741439599,
The agent does not report First Paint (FP) because the major players within the performance industry have decided to focus on these user-centric metrics. That's why we only want to report FCP.
If you want to include first paint with the page-load transaction, you could leverage the addLabels API and add a code similar to this one to your website:
window.addEventListener('load', function () {
const loadTransaction = elasticApm.getCurrentTransaction()
if (loadTransaction) {
const firstPaint = performance.getEntriesByName("first-paint")[0]
loadTransaction.addLabels({ "first-paint": firstPaint.startTime })
}
})
You can see that data on the transaction detail section:
data:image/s3,"s3://crabby-images/73984/7398438d4fef799a5d916d5745ed37f5f70fc644" alt="Screenshot 2022-07-28 at 21 41 38"
What is more, if you want to filter all the transactions with your new label, what you can do is to write this query in Kibana Discover:
data:image/s3,"s3://crabby-images/d5314/d531408f56bbde63fb450f5255d247c28d847954" alt="Screenshot 2022-07-28 at 21 44 59"
Cheers, Alberto