This is one of WordPress accelerating activities.
This article is for using WebP as image format to be sent to client.
– WebP: New image format which was made by Google.
Other improvements are in this article.
data:image/s3,"s3://crabby-images/51cf1/51cf1076fd64b5dfc5f607840add176d8755ddb1" alt=""
What I did
I use this as base docker-compose.
data:image/s3,"s3://crabby-images/29aa9/29aa9659cccf564946e02d1feefb0f66358aa444" alt=""
I installed this plugin to WordPress.
This plugin is cool because,
– Converting existing image file to WebP format.
– Converting newly uploaded image file to WebP format automatically.
data:image/s3,"s3://crabby-images/0cf73/0cf7345ff8c36534995c2a6d5f9c57a55eee216a" alt=""
I installed but faced below error.
– GD or Imagick has to be installed.
data:image/s3,"s3://crabby-images/9ff9c/9ff9c5749a96dea28e97ce7ac02581a5721cd68c" alt=""
I changed Dockerfile to install imagick.
RUN apt -y install libmagickwand-dev && \ pecl install imagick && \ docker-php-ext-enable imagick && \ (snip)
I faced another error.
– rewrite_not_executed means rewriting URL or something like that?
data:image/s3,"s3://crabby-images/483da/483da6460a94b2148dab87c8a5790062c988a2af" alt=""
I found
If you are using a Nginx server, ...
in this error message which indicates I need to configure Nginx.
I also found this configuration.
When I changed to Pass Thru, error message was removed.
data:image/s3,"s3://crabby-images/620a9/620a9ba8cc8aeab72ad3c81a70a60013b507f606" alt=""
If you use some cache plugins you need to delete existing cache before production.
data:image/s3,"s3://crabby-images/40f21/40f210976f2d107cba45fffa0df7c4121ff69db4" alt=""
I found button which converts existing image files to WebP.
data:image/s3,"s3://crabby-images/a4728/a472832094733ac044bd759fee76b60b76cba053" alt=""
About 20 mins passed after I clicked Regenerate All, then error happened.
There is 504 timeout.
data:image/s3,"s3://crabby-images/0fd40/0fd40433ae24269d6274dc414af1586d5c1a4076" alt=""
Timeout value has to be extended.
This is configuration of reverse-proxy which is https-portal.
Only need to add below line.
– This example shows setting 300 secs.
environment: + CUSTOM_NGINX_SERVER_CONFIG_BLOCK: 'proxy_read_timeout 300;'
This is timeout configuration of Nginx <-> php-fpm.
I added these lines to nginx/conf.d/default.conf.
server { location ~ \.php$ { + fastcgi_read_timeout 300; } }
I tried again.
After 1 hour, completed.
data:image/s3,"s3://crabby-images/b3282/b3282fa6a65f1019f51f722aa141ee9900bd0299" alt=""
You can confirm by accessing some blot post.
If you find content-type WebP is returned when you access image, then well done!
data:image/s3,"s3://crabby-images/830f3/830f3885efd6e66af4e9cf27c381dddbed60e65b" alt=""
Before vs after
I measured with below condition.
- Using LightHouse in Developers Tools of Chrome browser. Checking Performance only - Taking median as representative(n = 5). - Measuring on secret tab of Chrome.
Before
<—Mobile Desktop—>
data:image/s3,"s3://crabby-images/f8af5/f8af5aa130042efa72892509a03b29a18f2a006c" alt=""
After
<—Mobile Desktop—>
data:image/s3,"s3://crabby-images/63c16/63c16bfb2ebb2f24b81f8326f3a6e0cc966c8661" alt=""
Desktop has decreased, but Mobile drastically improved from 21 to 42 which is 200% higher!
Conclusion
How was it?
No program modification required!
Let’s do it , why not?
Comments