This website is hosted on a German server and I don’t currently use a CDN. So German visitors should be getting the quickest performance timings. But what about my homies in Cali or elsewhere?
I went to WebPagetest and tested a page containing the most resources using “Motorola G (gen 4)” mobile browser emulation and a “3G Fast” connection.
The Page is Rendered Quickest Outside of the Host Country. How Can That Be?
As expected, the time to first byte is shortest in Germany – that’s where I host my site.
data:image/s3,"s3://crabby-images/02557/025575b3949f9879bd4cf079396423932795d601" alt="WebPagetest Locations Comparison: Time to First Byte"
But tests run from three locations outside of Germany (Isreal, San Francisco and Dulles, Virginia) were visually complete before the German test.
data:image/s3,"s3://crabby-images/137f6/137f69b5383c1ea19e10e880edfb0446edf299df" alt="WebPagetest Locations Comparison: Filmstrip"
In fact, the visual progress of German test was pretty average compared to the other test locations.
data:image/s3,"s3://crabby-images/0504c/0504cd651474a6bad13b371f3840d650c3d9c195" alt="WebPagetest Locations Comparison: Visual Progress"
Apparently, the test from Dulles, VA was fastest to visually complete.
That seemed odd. If the physical distance between host and client is shortest in Germany, then shouldn’t the page finish rendering the quickest there?
data:image/s3,"s3://crabby-images/acac2/acac20bf6e987ce02938f81c531f3d74f5cc6a20" alt="WebPagetest Locations Comparison: Visually Complete"
More Bytes Sent to Dulles, VA
Then I had a look at Image Bytes and noticed: way more image bytes were being sent to Dulles, VA.
data:image/s3,"s3://crabby-images/de517/de5170ae011116f07c43f510192755960e62c133" alt="WebPagetest Locations Comparison: Image Bytes"
That’s when I realized:
If you test from “Moto G (gen 4)”, you’re testing on a real device – even if you select Browser Emulation.
data:image/s3,"s3://crabby-images/2c6b9/2c6b9ec4db5e940d4643c9b1254aa79d0c452f32" alt="WebPagetest advanced settings"
data:image/s3,"s3://crabby-images/a99a7/a99a7e92531afe11441d144adc943071f44535c4" alt="WebPagetest Chromium settings"
Indeed, when comparing test results from "Moto G (gen 4)” and “Virginia USA - EC2” (both with browser emulation), you see more image bytes are downloaded and an additional image request.
data:image/s3,"s3://crabby-images/00495/00495106f9c73c9e425da438b41be08e77300f59" alt="WebPagetest Locations Comparison: Moto G vs. EC2 Bytes"
data:image/s3,"s3://crabby-images/dd6bf/dd6bf786547e2999eadb3cbee98620ee6a20d644" alt="WebPagetest Locations Comparison: Moto G vs. EC2 Requests"
And performance timings around the board are better for "Moto G (gen 4)” than “Virginia USA - EC2”.
data:image/s3,"s3://crabby-images/ba5cb/ba5cbc93a05b8500a25a50966633d564effbab5e" alt="WebPagetest Locations Comparison: Moto G vs. EC2 Timings"
I then compared test results using only device emulation (no real devices) and Bytes and Requests were the same:
data:image/s3,"s3://crabby-images/f5b6e/f5b6e4ff2183ab5fb1a6d52b38bbae2fef8fa678" alt="WebPagetest Locations Comparison: Moto G vs. EC2 Image Requests"
Lessons Learned
Testing my website from around the world using WebPagetest taught me:
- When testing from various locations around the world, make sure you use emulation only – no real devices.
- Testing on real devices will of course give you more realistic performance timings than on emulated devices, but if you’re using public WebPagetest, the test location is Dulles, VA.