What is Real User Monitoring (RUM)?
Published 03 September 2020 11:27 (9-minute read)
Since the latest Google update about Web Vitals, search trends show an interest in the optimization of real user experience. In this post, I'll explain what Real User Monitoring is and how you can use it.
The simple answer to the question, "what is real user monitoring":
Real User Monitoring (of short RUM) is a method to collect user experience from real visitors from your website and store it in an application. This lets you collect information about how the users experience the loading of your website.
Unlike a general analytics program, like Google Analytics, which measures page visits and performs data sampling, RUM solutions focus on collecting all user experience data. RUM solutions also show the average and outliers of the collected data.
I've embedded a snippet from Google Trends where the latest search trends are shown.
Ps, here is the link to view the real-time Google Trends report for the above dataset about the "Real User Monitoring" keywords.
The big difference between Synthetic (for example, Lighthouse) and RUM is the fact that you influence the environment of the synthetic tests, you exactly know what the specifications and conditions are of the server/client that is running the test. These things may consist of network speed, CPU, GPU, RAM, and geographic location. All those aspects may impact the synthetic test.
In the case of RUM tests, the user environment is unknown, they could have a bad internet connection or a really old device with low specifications.
Some users even load your website (in the example hosted in Amsterdam) from a location on the other side of the world, let's say Sydney in Australia. When you don't use a CDN the requests have to travel half of the world, this leads to (milli-)seconds of waiting time.
You can do multiple things to reduce the load time what will improve the user experience. I've divided the improvements into 2 groups.
- server-side, for example: use a CDN, load balancer, DNS-based server usage.
First, an introduction to Web Vitals. What is this and how can you use them to improve your user experience on a website.
Web Vitals is an initiative by Google to provide unified guidance for quality signals that are essential to delivering a great user experience on the web.
Core Web Vitals is a subset of Web Vitals items (LCP, FID & CLS) that are the subset to focus on for 2020, they may change over time.
LCP: reports the render time of the largest image or text block visible within the viewport.
CLS: measures the sum total of all individual layout shift scores for every unexpected layout shift that occurs during the entire lifespan of the page.
More information can be found on web.dev/vitals.
Beside the Core Web Vitals there are others.
TTFB: identifies the time at which your server sends a response.
FCP: measures the time from when the page starts loading to when any part of the page's content is rendered on the screen.
TBT: metric measures the total amount of time between First Contentful Paint (FCP) and Time to Interactive (TTI) where the main thread was blocked for long enough to prevent input responsiveness.
TTI: measures the time from when the page starts loading to when its main sub-resources have loaded and it is capable of reliably responding to user input quickly.
The simple answer, you want to earn money from your visitors. So why don't you want to know how they are experiencing your website?
When your visitors don't have a good experience on one of your pages it's unlikely they are willing to try or buy your product. The first experience they have with your (online-)business can come via your website.
Google made a statement about using the Core Web Vitals as a ranking factor back in May 2020, they are planning to implement the Core Web Vitals as a part of their Search signals.
On November 10 (2020) Google announced that the Core Web Vitals will become part of the "Search signals for page experience". They plan to rol it out in May 2021.
Take a look at: Core Web Vitals will become part of Ranking Factor (in May 2021)
This change may impact your organic (SEO) and advertisement (SEA) when it goes live in May 2021.
We believe user engagement will improve as experiences on the web get better -- and that by incorporating these new signals into Search, we'll help make the web better for everyone. We hope that sharing our roadmap for the page experience updates and launching supporting tools ahead of time will help the diverse ecosystem of web creators, developers, and businesses to improve and deliver more delightful user experiences.
Take a look at Google's press release on their blog.
Most modern browsers support a method to collect information from your website visitors like Google Analytics collects information about the visitors (or use a privacy-focused solution like Fathom Analytics). These statistics can be collected and stored on a system that collects all the user experience data. Based on this data you can make changes and see if those are improving the user experience on your website.
If you don't want to store, aggregate, and monitor this yourself you can use a SaaS solution that is doing this for you. You only have to pay for the pageviews you use and they are storing, aggregating, and monitoring the user experiences. The main benefit is you don't have to worry about servers that collect all this user information, they handle will do this for you.
The methodic behind real user monitoring is not complicated, the logic behind it may look something like:
- On the moment a user interacts or leaves the site it will send the data to a collector.
- This collector processes all the incoming data from the visitor and stores it in a database.
- When the site owner wants to improve the user experience he can take a look into a dashboard to see which pages need some improvement.
If your website has enough traffic (visitors that are using the Chrome browser), it may be possible that you see "Core Web Vitals" data appear in your Google Search Console.
As you can see in the image above, the results are changing all the time. This because Google isn't measuring all the page visits to your website, only a small percentage of all visitors. This is because they only collect it from users that are using the Chrome browser.
Data for the report comes from the Chrome User Experience Report. This reflects actual usage data on your site from users around the world. (source: Google Search Console)
When you take a look into the documentation on Google support site it states:
Report data sources: The data for the Core Web Vitals report comes from the CrUX report. The CrUX report gathers anonymized metrics about performance times from actual users visiting your URL (called field data). The CrUX database gathers information about URLs whether or not the URL is part of a Search Console property.
So now you can see this information, nice. But you only know which pages on which devices are running slow and need improvements for the user experience. At the time of writing, it's not possible to see in Search Console which users (based on country or device type) have a bad user experience. It may be possible that those results are from a country that's far away from your server, this means you may need to add a world-wide network of servers for your website.
I created a free tool you can use to check your Chrome User Experience Report (or in short: CrUX). It loads the real user monitoring data collected by Google without adding your site to Google Search Console.
Also, Google announced back in 2019 that it's testing a feature in the mobile browser Chrome to indicate loading time for that website based on other users' experiences. Based on the blue of green loading bar users can see how fast the page normally loads.
When you search for RUM, you likely get the drink that's called "rum". But that's not what we need. We want "Real User Monitoring" solutions, so what are the possible SaaS solutions you can use on your site to collect user experience information? You can read more in the post "Real User Monitoring tools".