I’m always looking for ways to speed up my WordPress sites. Gravatars in comments has always been sort of a catch 22 situation. Typically the best thing to do is lazy load them, however, that causes other issues of which I’ll go into more below. Today, however, I want to show you how to load your gravatars from your own CDN. This is probably my new favorite method for speeding up comments!
For those of who you might not know, Gravatars are the icons associated with your email when you make comments on a blog post. These were developed and are managed by Automattic, the creators of WordPress. See example below.
One of the biggest issues people have with these is that they create a bunch of external requests on your WordPress site. Here is an example of one:
If you have 50+ comments on a blog post, you then wind up with tons of HTTP requests to gravatar’s external servers which looks like this.
And as you know, you have no control over assets/images that are on external sites. This means you can’t control the caching, the speed, or anything. You are left at the mercy of their servers. Thankfully gravatar.com is at least using HTTP/2 now. But there is still no comparison to loading the assets from your own CDN.
Some might wonder why I finally ditched lazy loading Disqus comments. The main reason is SEO. When you lazy load Disqus, and utilizing server-side caching, there are issues with crawlers reading the comments. And this means that comments can’t help boost your SEO. If you moderate your comments, they can, in fact, be free extra user-generated content on the page.
Why I Don’t Currently Lazy Load
I have nothing against lazy loading, and in fact have seen some great implementations of it. However, a lot of the plugins on the market for this have quite a few bugs, aren’t supported very well, or they don’t allow you to change the viewport. By viewport, I mean the time when the image actually appears when you scroll. In my opinion, there is nothing more annoying in my opinion than an image not loading until you scroll halfway down the page. I actually leaves sites that do that.
And I put “currently” above, because I very might well change this one day. But I have yet to see a satisfactory lazy loading plugin that is well supported, lets me change the viewport, works with responsive images in WordPress, and has a fallback for SEO indexing.
So one of my new favorite methods right now is to load Gravatars from my CDN. Technically you could both lazy load the gravatars and load them from your CDN if you wanted!
How to Load Gravatars From Your Own CDN
Now before I start out I have to give full props to the team over at KeyCDN for first blogging about this method. And some of this is taken from their article. As some of you may know, I used to work for KeyCDN. But am now just a happy customer.
I have used KeyCDN on all my sites for well over three years now without a single issue. I prefer it over Cloudflare, due to it not being a full proxy, and not having to mess with the full-page caching rules. And in my speed tests it has always been faster.
This tutorial assumes the following:
- You are running NGINX and have access to your server, or have a managed WordPress host such as Kinsta that allows you to add the following rules.
- You are utilizing the free CDN enabler plugin to deploy your assets to your CDN.
Open your Nginx config file and add “sub_filter” in the relevant location block. Replace “location /” with the directory for which you are using Gravatars and replace “cdn.example.com” with your CDN URL (such as https://cdn.woorkup.com/avatar/).
While still in the configuration file, add the proxy location for the redirected avatars.
Reload Nginx. Now all of the gravatar requests on your site should be going to your own CDN.
Gravatar Speed Test
I ran a speed test comparison to see the difference on a post that had 40+ comments. If you’re running your own tests I also recommend using KeyCDN’s free speed test tool or WebPageTest as they both support HTTP/2.
Gravatars Loading From secure.gravatar.com
I ran 5 tests from each location to ensure the assets (Gravatars) were being served from cache.
After Loading Gravatars From CDN
I then enabled the following rules above in NGINX and ran 5 tests from each location to ensure the assets (Gravatars) were being served from cache.
|Load Time (gravatar.com)||0.677 seconds||1.63 seconds||0.806 seconds|
|Load Time (CDN)||0.633 seconds||1.36 seconds||0.733 seconds|
It’s interesting to take a look at the results. When you load your gravatars from gravatar.com it will be serving them up from wherever their servers are. A real CDN such as KeyCDN is always going to have more POPs. Also, it reduces DNS lookups, because I’m already making a call to my CDN for my other assets. Here’s a summary of the difference:
- San Jose: decrease of 6.5% in load time
- Melbourne: decrease of 16.56% in load time
- Stockholm: decrease of 9.06% in load time
Not too shabby for a couple Nginx rules and utilizing a CDN I already had in place! This is probably one of the easiest optimizations I’ve done in years. Note: Keep in mind, this obviously will use more of your CDN’s bandwidth due to no longer offloading them to gravatar.com.
As you can see, loading gravatars from your own CDN allows you to reduce DNS lookups, take advantage of additional POPs, utilize a single HTTP/2 connection, and more! You’re almost guaranteed to see faster load times. Have you tried this on your WordPress site yet? If so, I would love to hear your thoughts below.
Get More Stuff Like This
Marketing, WordPress, Blogging Tips, SEO and Reviews, once a week.
Thank you for subscribing.
Something went wrong.