WordPressのスピードチューニングをしてみた

ここ数日、特定の記事へのアクセスが急激に伸びてサイト全体が重たいというのもあったのですが、何よりも投稿時に503エラーやらInternal Server Errorが出るなどのトラブルも続いていました。また、1年間いろいろなプラグインの追加や削除、テーマの改造などを繰り返した結果として、Google PageSpeed Insightの点数がモバイルで50点まで下がってるのが判明。

サーバープラン変更で転送量増やしたり、リソース増やすという力技も良いのですが、そもそもスピード低下は検索エンジンのSEO的に最悪の事です。という事で色々チューンしてみました。Pagespeed Insightに着目してるため、GTMetrixなどでは評価が真逆になる可能性もあります。

※なお、自分のさくらのPHPはモジュール版ではなくCGI版です。モジュール版に乗り換えれば更に高速化が可能です。現在移行ツールが提供されています。

※お知らせに書いてましたがボリュームが増えすぎたので、エントリーとして書き直しました。

目次

改善後の値

検証する時の注意点

PageSpeed InsightやGTMetrix、Lighthouseなどで検証をする際に注意点があります。これらを行ったうえで検証をしないと数値が改善しないと苦しむことになるので、事前準備してから実施しましょう

  1. Chrome拡張機能が数値に影響してしまうので、拡張機能入れていないアカウントを用意してプロファイルを切り替えてから行う事
  2. 素のChrome状態にしたら、WordPressにログインしていない状態にしてページを開くこと
  3. モバイルについては実機のスマフォでもオカシナ表示になっていないか?チェックすること(チューニングしたらモバイル側がおかしくなったということがあります)
  4. 検証結果でどこが悪いのか?はLighthouseのほうがやりやすいので、Chrome Developer Toolsは使えるようにしておくこと。
  5. チューニング前にfunctions.phpや追加のCSS、キャッシュ系のプラグインの設定値はバックアップしておくこと
  6. 重要視するのはSearch Consoleの値。結果が良くなって再検証実行しても反映するまで相当時間が掛かるので辛抱強く待つこと。

PageSpeed Insight、GTMetrix、Lighthouseそれぞれ違う数値が出たりするので一喜一憂はしないのが重要です。基準はPageSpeed Insightsとして対Google対策として取り組むことが寛容です。特に、1.については思いっきり数値に出てきてよく調べてみたら拡張機能が邪魔していたということが往々にしてありえます。

PageSpeed Insightの値

色々改善してみた結果としては、以下の図の通り。

モバイルで93点、デスクトップで99点まで改善する事ができるようになりました。レスポンスが非常に軽快になり、503エラーが低減しました。また、ページビューの観測比較をしてみた所、同じ曜日の先週、先々週との比較で49%増まで改善しました。

サイトスピードを放置してると色々損しますよという良い事例でした(機会損失したり、直帰率が増えたり様々)。

図:デスクトップの値はほぼ改善

図:モバイル側も大幅に改善しました

サーバリソースの低減

色々と改善してみた結果、ページビューは増加してるにも関わらず、同日先週比で相当数低減することが出来ました。

サーバ転送量で先週比で1.48GB減(27%改善)CPU使用率では先週比で84分減(34%改善)しました。サーバ契約転送量は上限が決まっているので、上位の契約プランに変更せずにだいぶ余裕を確保することが可能になりました。

また、ディスク使用量は最適化前は20GB/100GB契約を使用していましたが、最適化後は4GB/100GB契約(1/5)まで減らす事ができ、ディスク容量に相当の余裕が生まれました。

図:CPU使用率が減ることでレスポンスが改善

図:サーバ転送量が減ることでコスト節約

ページビュー等の改善

最適化をしたことでサーバリソース消費の低減になった事のメリットとして、ページビュー数などが2倍近く上昇しました。PageSpeed Insightの項目でも記述したように、レスポンスの悪いページは、Googleでのランクが下がります。また一方でレスポンスの悪いページは、ページビュー数が下がる統計的な傾向があります。いいこと一つもありません。

最適化をした事でGoogleページランクが上昇するだけでなく、そのユーザのサイト内でのページビュー数まで上昇させ、結果的には収益性もそのまま上昇させることに繋がるわけです。

2021年1月時点でのページビュー数がおよそ17,000、最適化後のページビュー数は、39,000。もちろん記事の増加やバズった記事などで変動もありながらも、それらを除外しても30000ほどであることから、如何にレスポンスの改善が重要なのか思い知る事例でした。

実施した改善策

プラグインの断捨離

全体のうち、6割改善効果があったのはプラグインの断捨離。すでにもうWordPress公式には掲載されていない古いプラグインを、後継のプラグインに変更したり、より軽量な別のプラグインに切り替えたり。改善の為にあえて追加したプラグインもありますので、減らせば良いというわけじゃないという点がなかなか難しいポイントでした。

現在はだいたい28個のプラグインを使っています。プラグインの選定は慎重に。

プラグインの削除と入れ替え

削除したプラグインは以下の通り

  1. WordPress Related Post -- 廃止されてたので、Yet Another Related Posts Pluginに入れ替え
  2. ARI Fancy Lightbox -- CSS関係で引っかかってたので、Responsive Lightboxに入れ替え
  3. JetPack by WordPress -- 廃止。これを止めるだけで、72点まで改善。
  4. Crayon Syntax Highlighter -- 古すぎたので、後継のUrvanov Syntax Highlighterに入れ替え
  5. Google Site Kit -- 最悪でした。入れただけで25点まで下がりました・・・速攻で削除

特にJetPackはNGでした。期待してた機能は他のプラグイン追加で対応させて、前述の数値を叩き出せてるので、メリットゼロ確定。古いプラグインは別のものに差し替えただけで、点数がわずかですが改善しています。

統計解析はもともとGoogle Analyticsを入れてるので、そちらで十分すぎるくらい把握できています。

代替プラグインの追加

Jetpackで担当させていた機能は他で代替させています。今回以下のプラグインを新たに追加して対応させました。前述のRelated Postのようにすでに代替させていたものもあります。

  1. Google XML Sitemaps -- Google Search Console登録用のsitemap.xml生成プラグイン
  2. SEO SIMPLE PACK -- SEO対策部分を対応。Analyticsコードの追加ウェブマスターツール認証なども担当

WordPress統計情報の代替

Google Analyticsでの代替

JetPackを使う目的の1つだったWordPress統計情報SlimStat Analyticsのような強力な統計解析を入れても良いのですが、今回の目的のウェブサイト軽量化には反するものになってしまいます。せっかく上げたPageSpeed Insightの値を大幅に落としかねません。

しかし、1つを除いて殆どはGoogle Analyticsで代替出来てしまいます。トラッキングコードはSIMPLE SEO PACKで簡単に追加ができるので、導入自体で躓くことは少ないと思います。AndroidアプリのAnalyticsで閲覧もできるので、むしろ統計解析が楽になりました。主に代替させたものは

  • 訪問先ページのカウント - ページビュー数でのランディングページで代替
  • 参照元ウェブサイト - ページビュー数での参照元で代替
  • 訪問時検索キーワード - ページビュー数での上位のキーワード
Google Tag Managerでの代替

ただ1つ問題が。Google Analyticsでは、離脱ページはわかっても、離脱先つまりクリック先が取得は出来ません。ウェブサイトにたくさん貼られてる外部のリンクの参照数は、Google Tag Managerでトリガーを作成し、WordPressにGoogle Tag Manager for WordPressを導入して、登録し、Google Analyticsへと連結が必要です。

結構複雑な作成手順が必要なので、こちらのサイトを参考に作り、コンテナを作り、コンテナIDをプラグインで登録しました。PageSpeed Insightへの影響は殆ど有りませんでした。

結果として、WordPress統計情報の一つである離脱先のリンクの情報を、Google AnalyticsにTag Managerを使って連結する事が出来ました。これで全ての統計情報を代替出来ました。

キャッシュの改善

これまで、ウェブページの最適化ではWP-Optimizeのみを使っていました。データベースのクリーニングの実施、ページキャッシュ、画像の圧縮が主な役割ですが、後半2つを別のプラグインに担当させて最適化を図りました。これで大体、1割くらい改善しています。

  1. AJAX Thumbnail Rebuild  -- 投稿した画像のサムネイルの最適化。普段は停止。
  2. Disable and Remove Google Fonts -- Google Fontの参照はPageSpeedにとってマイナスです。
  3. EWWW Image Optimizer -- 投稿した画像の一括圧縮を行います。無駄にバカでかい画像は縮小するに限ります。
  4. WP Fastest Cache -- 有名なキャッシュ系のツール。ページキャッシュとCSS, JSの圧縮ではOptimizeより効果が高かったです。

データベースクリーニングだと、Optimize Database after Deleting Revisionsを使うのも効果があります。

Plugin Load Filterの導入

地味に効果の高かったのが、このPlugin Load Filterの導入。実は、WordPressのプラグインは導入し有効化すると、編集画面でしか使わないものであっても、プラグインとしては通常のページでも負荷が発生するようで、編集画面でしか使わないものは、ページの側ではオフにするように設定するのが、このプラグイン。

ただし、Google XML Sitemapのようにページと編集画面両方で使うものをページの側でオフにしてしまうと、Googlebotがsitemap.xmlを読みに行けなくなってしまうので、慎重にオンオフをセットしましょう。自分が編集画面のみオンにしてるものとして

  • TinyMCE Advanced
  • Classic Editor
  • Disable Gutenberg

などなど。編集系プラグインばかりです。

functions.phpの改造

各Wordpressのテーマに同梱されているfunction.phpに直接記述をしてみて、若干改善効果があったものがありました。ただしテーマをアップデートすると上書きされてリセットされてしまうので、アップデート後は毎回、記述し直す必要があるのが面倒ではあります。

以下ソースコード

 

劇的に改善というわけではないのですが、いくつかPageSpeed Insightで引っかかってた項目がこれでクリア出来ました。また、自分が今使ってるテーマは、一部でGoogle Fontsを導入していたので、function.phpにてそのラインをコメントアウトしました。

Lightningの場合、noto-sansというものが遅延の原因となっていたので、google fontsの読み込み拒否としてコードに追記しています。

jsにasync属性を付与については、テーマなどによってはモバイルメニューボタンが動作しなくなるなどの不具合が出る可能性があります。

Adsenseコードの遅延読み込み

ブログがある程度軌道に乗って、サーバ代やドメイン代をAdsenseから広告収入を得て・・・と考えると、導入するのがGoogle Adsense等ですが、この時、AdsenseのJSコードをそのまま導入してしまうと、JSの読み込みがボトルネックとなって、かなりPage Speed Insightのスコアを落としてしまいます。

85点くらいのスコアが場合によってはこのコードだけで45点以下にまで落ちたりします。これがページの数だけ全て下がるのでかなり堪えます(特にモバイル側のスコアが下がります)。そこで、このAdsenseのコードを遅延読み込みに変えて上げるとスコアが一気に改善します。

  1. コードのうち、「<script async src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>」については削除もしくはコメントアウトする
  2. WordPressのテーマの場合はfooter.phpの一番下、Bodyよりも上のエリアに以下のコードを追記して保存する。このコードはこちらからお借りしました。
  3. キャッシュ系のプラグインを入れてるのであれば、一度全てパージをして再キャッシュする
  4. これでAdsenseコードが遅延読み込みされるようになり、画面のロード時間が飛躍的に上がります。

プラグインの設定

WP-Optimize

今現在はもう主力で使っていないプラグインですが、以前は主力で使っていたキャッシュ系のプラグイン。ただキャッシュ系の機能は後述のWP Fastest Cacheに任せたので、こちらでは以下の機能だけを利用しています。

  • 画像の圧縮 - Smush APIを使ってのアップロード画像の圧縮を行う機能
  • データベース - データベースのクリーニングを担当。予約クリーニングで常に最適化もできるけれど、リビジョンが削除されても困るので、手動で実行

キャッシュ、Minifyについてはオフにしてあります。

図:普段の画像の圧縮が主な仕事

図:実際の圧縮画面

WP Fastest Cache

キャッシュ系をメインで担当。主に

  • HTML圧縮
  • CSS圧縮
  • CSS結合
  • JS結合
  • ブラウザキャッシュ
  • Gzip圧縮

などをオンにしています。CSSやJSファイルは結合したり圧縮する事で、読み込み量を減らし高速化に貢献します。またキャッシュしておく事で何度も同じようなリクエストに対してはキャッシュから払い出すので、DBからの呼び出しを大きく減らし、また、データの転送においてはサーバ側が対応してる必要がありますが、Gzip圧縮を有効化しておく事で、高速化にかなり貢献します。

尚、自分のサーバがGzip圧縮が効いてるかどうかの確認は、Gzipチェッカーで確認すると良いでしょう。こちらのサイトでのチェックだとどれくらい圧縮されたかも確認可能。

図:キャッシュ系はもはや必須のプラグイン

図:Gzip圧縮はとっても重要

Plugin Load Filter

通常プラグインはその役割の範疇で動作するものなのですが、テーマファイルと干渉したり不要なページなのに動作していたりと結構ファジーな感じになっていたりします。特に管理者が管理画面でしか利用しないであったり、バックグラウンドで動作するため、「表示には関わらない」はずのプラグインが動作していて、結果的にPagespeed Insightのスコアを落としたり、セキュリティ面でもあまり好ましくありません。

そこで、このプラグインを利用して特定のページではそのプラグインの動作を停止させるというプラグインです。

Normalが通常動作、Adminが管理画面でだけ使うもの、Page Typeがページ毎に動作の可否を決めるものという形で指定が可能です。Page Typeは記事の編集画面でその動作を決める事が可能です。

図:何をAdmin限定にするかでOK

Async JavaScript

このプラグインは、JSの読み込みを遅延ロードさせる事で、サイトの描画を優先しPagespeed Insightの評価アップに繋がるように入れています。特にモバイル側でのポイントが場合によってはかなり上がるのでオススメです。

特に設定もせず、インストールしたらそのまま使っています。

図:更に細かいチューニングも可能になってる

Native LazyLoad

Google提供の画像の遅延ロードをさせる為のプラグインがNative LazyLoad。インストールして有効化するだけのお手軽仕様です。画像の遅延ロードもPagespeed Insightの評価ポイントの一つになっているので、入れておいて損はないと思います(ただ、2年前に開発が止まってるのが気になる)。imgとiframeタグに関して、自動的にloading="lazy"と付けてくれることで、実現してるだけのプラグイン。

似たような遅延ロードさせるプラグインとしては、Lazy Load (作者:WP Rocket)があり、こちらは現在も開発が続けられています。

その他

これは契約サーバによる所が大きいですが、このサーバの場合、国外IPアドレスフィルタが、WAFとは別に用意されています。WAFは攻撃に対しては効果は高いのですが、コメントスパムのような厄介な連中を防げるわけではないので、国外IPアドレスフィルタは非常に効果的です。

特に中国・ロシアあたりからの無駄なアクセスはリソース消費の原因になり、503エラーを頻発させた上に、スパムがじゃんじゃん届きます。Akismetプラグインである程度防げるといっても、実際に問い合わせフォームからたくさん、要らないお手紙が届きました。国外からの概ねのアクセスを遮断することも少ない資源を活用する上では重要です。

※サーバレスポンスの悪化は当然、PageSpeed Insightの点数を下げる大きな要因になります。

2021年 再度挑戦

時が経過すれば、それだけプラグインの追加やテーマの更新等により折角最適化してスピードアップしても、激減する事がままあります。Bizvectorが開発終了に伴って、Lightning + VK All in One Expansion Unitに切り替えて様子見していましたが、Google Pagespeed Insightの成績が激減し、50を下回る事に。以下、原因を追跡してみました。

※今回はモバイルを80ポイント以上を目指します。

図:激減したスコア

全てのプラグインをオフにして見る

一番原因となってるであろうは、追加されたプラグイン達。これらがボトルネックになってる可能性があるため、一旦全部停止して、スコアを見てみることに。すると、以下のような結果が得られました。

この結果から、Themeに問題があるわけじゃないということがわかります。

図:スコアが劇的に改善

プラグインを一個ずつオンにして検査

次にプラグインを一個ずつオンオフしてGoogle Pagespeed Insightで調査。結果、スコア低下に大きな影響与えたプラグインは以下の通り。

  • vx expansion unit(47Pも下がった)
  • Responsive Lightbox
  • What's New Generator
  • kk Star Ratings
  • Shortcode Star Rating
  • Ad Inserter
  • SEO SIMPLE PACK(10P以上下がる)

特にBizvectorから移行時に推奨されていたVX All in One Expansion Unitが物凄く下がる。他、レーティング系のプラグインもかなり悪影響で、SEO系での相当のパフォーマンス低下を引き起こしていたので、無効化してみた。とは言え、VX All in one Expansion Unitは色々な役目を担ってるので、ここをまずは深堀りしてみる。

図:特にモバイル系のスコア低下が酷い

色々プラグインをリストラ&最適化

大きくサイトに影響を及ぼしていた前述のプラグイン、これらをまず全停止してVX All in one Expansion UnitおよびSIMPLE SEO PACKは無効化のままにし、他は削除してみました。他の問題ないプラグインを有効化した後に、再度テストを実行してみると以下の結果が得られました。

図:問題ないプラグインは本当に影響を及ぼさない。

しかし、これではリストラした分だけサイトの利便性が下がってしまってるので、代わりになるプラグインを調べ上げて一個ずつ調査。影響が低いものを選別し以下の処置をしてみました。

  • トップページに戻るボタン ⇒ to topプラグインで代替
  • Lightbox系を代替必要 ⇒ Easy Fancyboxで代替
  • レーティング系プラグインは使わないようにする(全部リストラ
  • CSSカスタマイズ ⇒ 標準のカスタマイザーで対応
  • Googleタグマネージャの代わりをみつける ⇒ Google Tag Manager for WordPressで代替
  • 関連記事表示 ⇒ Yet Another Related Pluginで代替
  • Google Analytics関係 ⇒ True Lazy Analyticsで代替(Analyticsコードの遅延読み込み)
  • Google Adsense関係 ⇒ 取り敢えずオフにしておく
  • キャッシュ系 ⇒ WP-Optimizeに一本化(WP Fastest Cacheは500エラーが頻繁に出たので廃止)

VXが担っていた殆どの機能を専門のプラグインに変更してVXオン時と比較するとVXにやらせるよりも、専用のプラグインのほうがパフォーマンスが良いので、VXとしては上記の担当機能は全部外しました(実質使ってるのは、カスタム投稿タイプの機能くらい)。カスタム投稿タイプもCustom Post Type UIに入れ替えて実験しましたが、殆どスコア変わらずなので、こちらに交換してVXはリストラでも良いかなと思います。

ここで判明したのが、VX All in One Expansion UnitにてAdsenseコードの反映を使っていましたが、これが40ポイント台まで下落させている一番の元凶だと判明。Adsenseコードの直貼りは、害悪以外の何物でもないのがよくわかりました(Pagespeed Insightが下がるとSEO的にはマイナスとなるので、広告の意味がない

よって、VXもオンにしてみて、上記の機能をオフにし、専門プラグインに任せ、Google Adsenseの機能も外してみた結果が以下の通り。SIMPLE SEO PACKをオンの場合は、デスクトップが90ポイント、モバイルは88ポイントでそこまで壊滅的に影響を及ぼしているわけじゃないとわかったので、再度オンにしています。

図:多少下がったけれど、これは仕方ない

個人的今後絶対に入れないプラグイン

長年、WordPressを利用してきていますが、非常に具合が悪い、スピードパフォーマンスの低下を招くなどで今後もう絶対に入れないだろうなというプラグインは以下の数点。

  • JetPack - ウェブで勧めてる人いるけれど、パフォーマンス低下が酷すぎるので入れません。
  • Autoptimize - 色々とトラブルが出て散々な目にあったので
  • WP Total Cache - こちらも同上。キャッシュ系は本当によく選ばないとだめだね。
  • Google Site Kit - Google提供のパフォーマンス低下するだけのプラグイン。ハッキリ言って要らない
  • All in One SEO - パフォーマンス低下が他のSEO系に比較して大きい為排除

いかに便利であろうとも、どんなに利便性があがろうとも、ウェブサイトというものは人に見てもらえてナンボ。Webfonts系などもハッキリ言ってパフォーマンス低下しか招かないので基本排除しています。

何よりも、Search ConsoleやPagespeed Insightに影響が出るようなプラグインなど、ページランク下げて見られなくなるだけなので、Google検索基準で作らないとウェブサイトは意味がない時代になってる。また、ユーザにとっても何秒も表示に待たされるページはストレスでしかない(人間が待てる最大の時間は最大3秒間と言われる)。

WordPress側もスピード評価を入れて頂きたい。

Analyticsコードを遅延読み込み

Adsense同様、第三者コードとしてものすごくスピード評価の低下を招く要素がGoogle Analyticsのコード。故に普通に挿入するプラグインやテーマファイルに書き込んで置いても、スピードダウンします。よって、これを遅延読み込みするプラグインにて対応しました。

前述のTrue Lazy Analyticsがそのプラグインで、UAから始まるトラッキングコードを登録するだけ。実際に他のプラグインの場合相当下がっていますが、このプラグインの場合、速度低下を招かずに遅延ロードしてからトラッキングを行うのでスピードダウンしません。但し、遅延読み込みしている関係で若干正確性は失われますが、スピード低下のほうが大問題なので、ここは由しとしました。

特に第三者コードの影響を抑えてくださいという項目で顕著で、メインスレッドが○秒ブロックされたという事で、先にAnalyticsの処理が走ると終わるまで他のJSの読み込みなどがブロックされる為、遅延読み込みの効果は非常に高いです。

※また、やりがちな大チョンボとして、SIMPLE SEOなど他のプラグインでAnalyticsのトラッキングコードを入れてるのに、他のプラグインでも同じように入れてると、ダブルカウントされてしまうだけでなく、二重にJSをロードしてたりするので激重になります。自分のサイトでテーマ付属やプラグインなどで二重でトラッキングコードを入れていないか?もチェックしておくべきでしょう。

広告コード

Adsenseコードを遅延読み込み

どんなプラグインの影響よりも、やはり壊滅的に影響を与えているのは「Google Adsenseのコード」であることがよくわかりました。拡張機能の癖して遅延読み込みといったものに対応していないという状態では、正直ちょっと使えないです。ということで、前回同様の処置をしてみます。今回は自動広告のケースについて記述しています。

  1. テーマエディタを開き、Lightningテーマの場合は、_g2および_g3のfooter.phpにある</body>の前に対して前回同様の遅延読み込みコードを記述する(但し、テーマを更新すると初期化されてしまうので要注意
  2. ca-pub-xxxxxxxxxxの部分はAdsenseから取得したコードを入力しておく
  3. ファイルを更新をクリックする
  4. 自動広告ではなく、意図して挿入する広告の場合は、googlesyndicationのjsのコードは削除し、以下のようなコードをテキストウィジェットなどに貼り付ける。ca-pub-xxxxxxxxxxやdata-ad-slotについてはAdsenseから取得したコードを入力しておく。
  5. 一応、WP Fastest Cacheなどを入れてる場合は、キャッシュをパージしておき、ページをリロードして広告が表示されるまで待つ
  6. 広告が出るようになったら、再度、Pagespeed Insightにてテストをする

この結果、以下のような結果が得られた。殆ど広告表示によってスコア低下が発生する事がなくなり、レスポンスが向上。以下のコードは、2021年7月以降の新コードに対応させたものになります(広告自動挿入の為のコードになります。通常のブロック挿入の場合も殆ど同じような感じです)

図:目標達成。これで引き続き安心して運営を続けられる

図:遅延ロードのコードの書き込み先

他の広告コード

A8.netもしもアフィリエイトのようなサードの広告コードについては、こちら側でどうこう出来るものではないのですが、貼っているとPagespeed Insightのチェックで頻繁にCLSの問題、読み込みの遅さ、画像の圧縮不足、テキストの圧縮関係で怒られます。自分のWordpressで配信してるものではないので、これらの最適化は出来ませんが、Adsense同様にロードの遅延読み込みをさせることで若干軽減が可能です。

Ad Inserter Proを購入し、広告コードを管理することで、各ページに直接貼らずにショートコードで挿入、キャッシュ機能もついてるようですが目的は遅延読み込み。Misc⇒Display⇒Lazy Loadingにチェックを入れて保存で、広告コードの遅延読み込みが実現出来ます。

図:遅延読み込みオプション

Youtubeの埋め込み

実は、Youtubeの動画のコード、アレの埋め込みはPagespeed Insightのチェックではものすごく評価を下げる原因になっています。ましてや、複数の動画を貼り付けるとなると非常に表示自体にも影響する。だからといって貼り付けないというのもちょっと困る。そこで利用するプラグインがWP Youtube Lyteです。

既存のYoutubeの埋め込みリンクを置き換えもしてくれますが、Lite Youtube Embedのようにサムネイルをキャッシュし、ボタンをクリックされるまではロードさせずに待機。ボタンをクリックすると初めて動画のコードが読み込まれる仕組みになっています。使い方はちょっと事前準備が複雑なのでまた機会があれば記述しますが、基本はインストールして終了です。

自己評価では、30まで下がっていたとあるページが、プラグイン導入後は50以上まで回復しました(5個くらい動画が貼り付けてありました)

図:埋め込みの見た目はコレまでと同じ感じ

functions.phpの改造を追加

前述のfunctions.phpの改造のうち、サムネイル生成・jsにasync属性を付与以外のコードをfunctions.phpに追加した上で再度Pagespeed Insightでテストしてみました。デスクトップはほぼ変わらずですが、モバイルがそこそこスピードアップに繋がりました。

追加で、JS読み込みを非同期化するプラグインを導入し、そこそこ効果があったと思います。

※Lightningの場合、jsにasync属性を付与の改造コードを追加すると、スマフォでのハンバーガメニューが動かなくなるので外しておく必要がある。

図:モバイルも合格圏内の90ポイントまで持ってこれた

逆にプラグイン追加で改善したもの

これまでの改善を踏まえて、最後に新たに2つのプラグインを追加しました。Async JavaScriptおよびNative Lazyloadの2つ。入れたことによって、スピードアップが更に改善されて、スコアが以下のようになりました。

これまでトップページだけでテストしていましたが、フルで色々表示してるエントリーページはトップよりも評価が低かったのですが、これがかなり改善されました。モバイル側は殆ど変わらずですが、デスクトップ側が大きく改善。

尚、Lazyload系プラグインは他のプラグインでも提供されていたりして、干渉しやすいので慎重に。

図:デスクトップ側が大きく改善した

画像の超最適化

WP-Optimizeを使ってる理由の一つとして、Smush APIを使ってアップロードした画像の圧縮をしてくれるという利点があります。これによりスクショや写真などを圧縮して最適化し、ロード時間の短縮化を図っています。

しかし、これでもまだまだで、更に上のWebP形式というものがあり、IE以外の主要なブラウザは対応済みで、透過色にも対応している為、Animation GIF以外の形式はオリジナルよりも更にファイルサイズを小さくすることが可能です。(Smush APIで圧縮したものをSquoosh(Googleが提供してるサービスの模様)にて圧縮すると30〜50%さらに軽量化出来ました)

一個ずつ手で変換がアレという人はWebP Converter for Mediaというプラグインをインストールして、一括変換を掛けることも可能。オリジナルはそのままに違うディレクトリに変換してくれます。プラグインを無効化するとオリジナルの画像表示に戻る仕様になっています。こうする事で全体的な転送量の削減にも繋がる為、さらなるスコアアップが期待出来ます。

これだけ圧縮してるにも関わらず目立った画像の劣化も無く、またIE11はWindows11でいよいよサポートされなくなった事で今後もう考慮する必要性もなくなったので、WebPへの移行をしても良いのではないかと。

※85%でプラグインにて変換掛けてみましたが、全画像トータルで630MB分くらい削減出来ました。ただ、一部の画像はWebPのほうが大きいケースがあるのでその場合は処理がスルーされるようになっています。ファイルは拡張子はオリジナルと同じままでwebpにはなっていませんが、Chrome Devtoolを使って調べると、きちんとWebPになっていました。

図:更に画像を圧縮してスコアを稼ぐ

図:きちんとWebPに変換されてたケース

図:一括変換中の様子

Lightning Themeについて

Bizvector後継ということで利用してるLightningテーマですが、このテーマにはCSS関係で色々。

まず、標準機能であるLightning CSS最適化Tree ShakingというCSSをインライン化し主要なものだけを利用に限定する機能。これをオンが推奨であったので、変更したことで若干パフォーマンスが改善。また、Preload CSSというCSS読み込みを遅延化する機能。これもオンにすることで、一部ブロッキングしてた要素の問題が改善(但し、これのせいでパフォーマンスが落ちる事がある)。

気になったのが、ずっとPagespeed Insightのモバイル側で出ていた2つのCSSについて、利用されていないであったり、ロードでブロッキングが発生してると指摘されていた項目があり、bootstrap.min.cssとall.min.cssの二種類。これがブロックしてるようなのだけれど、外すとレイアウトが崩れる(デスクトップ側で)。困ったものだ。

細かい事ではありますが、こういった無駄やオカシナ点も手動で直していく事で軽量化に繋がります。テーマを更新したらまた発生するのでちょっと手間ではありますが。

図:これはテーマ自身の問題点

.htaccessの設定変更

プラグイン系でもこの.htaccessの設定変更でパフォーマンスを稼ぐ手法をキャッシュ系が行っていたりしますが、現在の自分のWordpress環境だと記述がなかったので、追記したのが「テキスト圧縮の有効化」。自分のサーバから発信するデータに対して、テキスト系のデータを圧縮するものです。

WordPressインストールディレクトリ直下にある.htaccessファイルを以下の項目を追記。

改善項目で出ていたテキスト圧縮についてこれで改善されて僅かですがパフォーマンスも改善。WP-Optimizeのほうではgzip圧縮の追記については行ってくれてるようなので、追記せず。

※ただしさくらのレンタルサーバの場合、WAFをオンにしているとgzip圧縮の情報が送られずテキスト圧縮の有効化が無効化されるようです。よって、WAFをオンにすると防御力はアップしますが、どうしてもLCPやFCP、Speed Indexが相当落ちます

拡張機能でパフォーマンス測定

Chromeの拡張機能で調査

LCPやらCLSやら現在のウェブの指標は非常に細かくなってきており、それらの結果として速度に現れ、Pagespeed Insightに評価が出ています。それらを細かく追跡するのに非常に役に立つChrome拡張機能が、Web Vitalsです。

Chromeに拡張機能を入れて、対象のページを開けば指標が計算されて色とポイントで表示されます。Developer Toolsを開くとLighthouseという項目タブが追加されており、ここからLighthouseでの検証が可能(但し、拡張機能などを色々入れていると非常に影響を受けて低評価が出るので、使うならば殆ど拡張機能を外した状態のChromiumなどを用意して検証が必要)。また、この機能はモバイルのみの計測となります。

計測要素のうち、「Interaction to Next Paint」は表示してから一端スクロールやテキストボックスにフォーカスしてから計測すると出てきますので、計測時は表示=>スクロール=>計測実行で行うと良いです。

同様にGoogle提供のLighthouse Extensionのがありますが、現在はChrome自体に統合されましたので、Developer Toolsを開き、Lighthouseタブを開いて実行しましょう。

※検証をする場合は、拡張機能などが邪魔したりもするのでシークレットモードでChromeを起動してからテストすると良いです。

図:この指標が緑色になるように色々チャレンジ

図:Lighthouseの検証結果

図:LighthouseはPuppeteerで動いてるようだ

WordPressプラグインで調査

WordPressにプラグインで追加した形で特に「DBのクエリパフォーマンス」を測定する為のプラグインとして、Query Monitorがあります。さらにアドオンなども用意されているようです。

インストールすると上部の管理バーに数値と色合いが表示される仕組みで、数値は左から生成時間、メモリ量、クエリ実行時間、クエリ回数が表示され、あまりにも遅いと「赤色」で表示されるようになっています。プラグインなどによるDBアクセスなどもあまりにも多いとここがボトルネックとなるのがよくわかります(どのプラグインがボトルネックになってるか?が何回も測定するとよくわかります。

基本、表示したいページを開けば自動計測されます。細かいオプションや設定が沢山あるので、突き詰めたい人は入れておくと良いでしょう。

図:DBアクセス量は表示に影響が大きい

GTMetrixでも評価を出す

前述までのチューニングの結果、たしかにPagespeed Insightでの評価はかなり上位の所まで持ってくる事はできました。しかし、いざGTMetrixLighthouse(Web Vital Extension)の検証を行ってみると、物凄い評価が真逆で悪い。これはPagespeed Insightがパフォーマンス重視の検証に対して、GTMetrixやLighthouseはパフォーマンス以外のSEO、アクセシビリティなどの総合評価となる為。

また、Search Consoleに於いて、LCP の問題: 4 秒 超(パソコン)という形で不良URLが多数出てくる結果が。つまり何かがLCP項目のボトルネックになってる。これを次に解消する為にさらにチューニングをしてみることにしました。一度、VK All in One Expansion Unitを再度元に戻して実験です。

図:Search Consoleでの結果ががが

Lightning ThemeのPreloadはオフ

テーマ付属のCSSチューニング機能であるPreload CSSについて。キャッシュプラグインとの相性が悪いのか?オンにすると評価がグッと下がる。。ということで、Tree ShakingはオンのままPreload CSSについてはオフにしました。おおよそ10Pほど改善。

図:テーマ独自の機能も影響大のものがある

プラグインをさらに断捨離

テーマのアップデートやプラグインの断捨離、入れ替えなどで直近で入れたプラグインが逆に悪影響を及ぼすケースというものがあります。直近で入れておいたものも含めて以下のプラグインを断捨離しました。

  • Async JavaScript - WP Optimiseの影響か外すとパフォーマンスが改善
  • Native LazyLoad - Pagespeed Insightでは効果見られるも、GTMetrixでは外すと結果が出るので、外すことに
  • Redirection - ページの移動など対策のリダイレクト設定や404のエラーを捕捉するために入れていたが、かなりパフォーマンスに影響していたみたいだ。
  • WP External Links - 外部リンクにnofollowやrel属性、target属性を加えるものだが、これもパフォーマンスにかなり影響していた
  • Pz-LinkCard - トラブルも出ていて、それが猛烈にパフォーマンスに影響が出ていたのでオフに(現在代替案考案中)。古いプラグインはこういう事があるのでなるべく使わないようにしないといけない。
  • AddToAny Share Button - SNS共有ボタン追加機能だけれど、この手のツールは結構パフォーマンス低下では堪える。ので、排除し、自作のものに置き換えておきました。

Ad Inserter Proの設定変更

広告を遅延ロードさせるLazy Load機能がついていたのでテストしていましたが、キャッシュプラグインとの相性の悪さやJSの遅延ロードなどとバッティングするからなのか、表示されないケースがあったので、Lazy Loadについては外してみた。つけてもつけなくても正直あまり評価に影響がなかった・・・

図:キャッシュもしてくれてるみたい

WP Optimizeの設定変更

WP Fastest Cacheをやめて一本化しましたが、結果、Easy FancyBoxが動作しなくなっていたので、以下の設定変更を加えてみた。

  • モバイル端末用に別のファイルを生成はチェックを外す
  • MinifyのJSに於いてDefer all the JavaScript filesのままで、Defer jQueryのチェックは外しておく
  • DBクリーンアップに予約設定を毎週で入れておいた

図:遅延読み込みでjQueryは外しておく

VK All in One Expansion Unit

一旦元に戻したこのプラグインで担当させているものは

  • ウィジェット
  • 関連記事(Yet Another Relatedをオフ)
  • XMLサイトマップ無効化
  • カスタム投稿タイプマネージャー(Custom Post Type UIをオフ)
  • ページトップへ戻るボタン(To Topをオフ)
  • CSS最適化

にして、AdsenseやAnalyticsについてはオフのままで運用(他のプラグインやfunction.phpでの対応)

カードレイアウトを自作

Pz-LinkCardを排除してしまったので、コレをどうにかしないといけない。ということで、これを簡単に実装出来ないかなぁと思い、以下の手法で作成しました。

  • デザイン担当のCSSはテーマの追加CSSに記述しておく
  • カード本体は手動でHTMLを直接エントリー内に記述する

それほど多用するものではないので、これで十分実用になる。カードのレイアウトそのものは、こちらのサイトのものを利用。ちょっとだけ改造してあります。これで、プラグインでの大幅なパフォーマンスダウンは防げるようになりました。

図:非常に単純だけれど立派なものが出来た

複数キーワード検索全角対応

WordPressって細かい所で残念な場所があって、その中の1つに「スペース区切りで複数キーワード検索時に全角スペースが使えない」というものがあります。故に、英語が苦手な人がサイト内検索をした時に目的のものにたどり着けないで「検索結果なし」が返るのです。これではせっかく来てくれた人に大変申し訳無い。しかし、このためだけにプラグインを入れるというのものスピード的にどうか。

ということで、自作して全角⇒半角に変換してサーチするように関数をオーバーライドしてしまう方法があります。

※但し、Lightningテーマの場合、雑談・お知らせとして別カテゴリー(カスタム投稿タイプ)にしてる内容が検索で引っかからなくなるという副作用があったので、自分の場合このまま常用はちょっと難しい。

  1. WordPress管理画面の外観⇒テーマファイルエディタを開く
  2. functions.phpを開く
  3. この中に以下のコードを追記する
  4. 保存して実際にサーチしてみて無事に引っかかればOK

SNS共有ボタン

WP Social bookmarking lightやらAddToAny Share Buttonといった、いわゆるSNS共有ボタン。実は調査してみるとわかりますが、かなりパフォーマンスの面(特にJSやCSSといったファイルのレンダリングブロッキング)にて、悪影響が強いです。確かに便利ですし、今どきのブログには必須のパーツなのですが、かなり気になるレベルでポイントを落とす原因になっています。

一方、使う共有ボタンは本当に限られていて、頻繁に交換するモノでもないので、プラグインを排除し、自作のものを利用することにしました。詳細はこちらにあるサイトsns.phpを自作し、テンプレートフォルダ直下にアップ、それをウィジェットで自分は呼び出すようにしています。ただし、リストタグをアイコン化するタイプの表現があまり好きではないので、CSS表現に関してはこちらのサイトのものをお借りしています。

ウィジェットからはこちらのサイトにあるPHPコードを呼び出すように改造を加えています。ちょっとまだ無骨なので、デザインはさらに改造を予定。しかし、これによりかなりモバイル等でのスピードアップが実現出来ました。以下は自分がちょっと加工を加えた版。

GTMetrixとLighthouseで検証してみた

これらのチューニングを施した結果を持って、GTMetrixでトップページを検証してみた。以前はD評価で非常に状態がよろしくなかったのですが、A評価を得ることが出来ました。もちろんPagespeed Insightでの検証結果も良好なものが得られました。

図:GTMetrixでの検証結果

 

図:Pagespeed Insightでの検証結果

図:Lighthouseでの検証結果

さくらレンタルサーバ特有の設定変更

メモリサイズを調整する

さくらのサーバのWordPressは遅い!!確かに遅い。という話を結構ウェブで見かけます。事実遅いです。そこで調べてみた所、Debug内容に「Fatal error: Allowed memory size」の文字が。どうも、デフォルトのままで利用していると、割り当てられてるメモリを食い尽くすらしく、以下の設定をする事でとりあえず軽くすることができました。

  1. さくらのサーバーコントロールに入る
  2. スクリプト設定⇒php.ini設定を開く
  3. 以下の記述を追加して、保存するをクリックする

どうも、デフォルトだと140MB程度で上限設定がされてるらしく。。上記の設定を施した所、緩和されました。

移行ツールでサーバを乗り換え

2022年7月、旧式サーバから新サーバへの移行ツールが提供されました。これにより、当サイトも新サーバへ契約手続きナシで移行できる事になり、使ってみました。しっかりWordPressもDBサーバ設定も移行されて、特に手作業ナシで移行が完了しました。コレにより

  • PHPがCGIモードではなくモジュールモードで利用可能になりました。
  • 新サーバはスペックアップしている為、レスポンスがアップしました。
  • SSD採用のサーバであるため、ディスク読み書きスピードが向上しました。
  • これらにより、503エラーの頻度が低下しました

特にPHPのモジュールモード変更はサイトの高速化では特にPC向けサイトで顕著に効果が出て、途中で離脱であったり、503エラーの低減による機会損失の低減が期待できます。

※ただし移行ツールは利用者が集中すると利用できない事があるので、その場合は翌日に申し込みをしましょう。

図:移行ツールは混雑してることもある

未使用のテーブルを削除する

プラグインの類を入れたり削除したりしていると、年数を経る毎に、WordPressを設置してるレンタルサーバのMySQLサーバに於いて、使っていないテーブルというのがごちゃごちゃと残っていきます。

通常これらのテーブルは未使用というだけなのでデータが入っていても問題はないのですが、レンタルサーバの場合はそうはいかない。それがこれらがDBの容量を無駄に圧迫し、また中には記事のリビジョンなどがそのままの状態で残っているとやはりスピード面で大きな劣化を生じます。この問題を解決するプラグインがWP-Optimize

機能の1つとしてデータベースのクリーニング機能があり、それは前述で書いたとおり。定期的に実行しましょう。それ以外にもテーブルタブを開くと、「not installed」といった赤い文字で表示されてる使っていないテーブルなどを表示し、これをプラグイン上で削除できる機能が備わっています。

Removeボタンが表示されてるので、使用していない過去のプラグインの残骸テーブルは徹底的に削除してしまいましょう。プラグイン名も表示されてるはずなので、不要・必要の区別はつくはずです。この作業の結果、かなりパフォーマンスが復活しました。6年も運用してるとこういう事例が生じるので、一度点検してみましょう。

2023年末チューニング

時間が経過する毎に色々と外部状況も変わってくるので、ウェブサイトのチューニングも変わってきます。特にGoogleのコアアップデートによって重要視される指標に大きな変動が発生した場合には、それまではオッケーだったサイトの評価が一気に下がるといったこともしばしばあります。

そこで2023年末に再度、Pagespeed InsightおよびLighthouseにてチェックしつつ、Search Consoleで警告を受けてる指標について修正。その内容を備忘録としてここにまとめておきます。

改善結果

Lighthouseでの結果

このページ自体をLighthouseで調査してみたところ、35点という驚愕の数値に成り果てていました。そこで、以下の改善や以前行ったいくつかの改善を行って細かく細かく調整を加えたところ、MobileおよびPCで以下のように改善出来ました。

毎回もう余計なことしない!!と自分で決めていても、年を経る過程の中で余計なことをしてしまい数値を落としがちなのですが、回復させる事ができました。ベストな設定をメモしておくことも重要です。

図:PC側での改善結果

図:Mobile側での改善結果

Search Consoleへの反映

いくらLighthouseやPagespeed Insightsでのスポットのテストが好調であっても、その結果は即時にSearch Consoleでのスコアの判定に反映されたりしません。あの数値は多くのユーザがアクセスした結果や検証時のアクセスにて検出された数値の平均値を持ってして出されているものなので、前述のテスト結果が良かったとして、そこでSearch Consoleで検証を開始しても、反映するのに最大28日以上掛かることになります。

2023年12月初旬に検証スタートして、2024年1月上旬で観た所、ようやく検証結果が反映されてきて、PCに関してはほぼ問題の無い状態になったことが確認できました。Mobile側はチューニングが遅れた為、まだ途中ですが徐々に成果が出てきたのが確認できました。まだ、一部で改善必要な項目がありますが、殆どがLCP項目(つまりAdsenseやもしもアフィリエイトなど)が悪さをしてるので、ここをクリアすればページランクにも反映するのではないかと思います。

※2024年3月から開始される新指標であるINPについても改善しました。ユーザのアクションに対する応答スピードに関する指標なので、jQueryやらJavaScriptでバリバリ表現してる場合かなり注意が必要です。

※チューニングして全ページが良好になるまでモバイル側は2ヶ月掛かりました・・・結果的にアクセス数も向上してきました。

図:検証結果はのんびり待つ必要があります

図:INPの値も改善しました

CLSの改善

概要

とくに今回改善を要したものが、CLS。この指標は前からありましたが、このサイトでは常に評価がよろしくなかった。その原因はGoogle Adsenseの自動配信広告。CLSが悪化する一番の原因は画像などの広告に対してあらかじめ「高さ」を指定して場所を確保していないような場合、明らかにこの数値が悪化します。これを0.1以下にしなければならない。

Google Adsenseの自動広告配信は便利な反面、自由気ままに記事に投稿してしまうので見てくれも悪くなりがちです。ということで、こちらのサイトを参考に以下の処置を追加したところ、CLSのポイントがほぼ0になり一気に改善しました。

  • 自動配信広告のページ内フォーマットは全部廃止
  • オーバーレイフォーマットのサイドレール広告は鬱陶しいので廃止
  • 記事内のAdsense貼り付けは、Advanced Adsプラグインを導入して手動広告を貼り付けに変更(記事の場所を明確に指定できるので邪魔にならない)
  • 手動広告のコードは次項のように改造する

図:こんな状況になってました

図:CLSが見事に改善

Adsense広告の貼り付け手法

これまでもAdsenseのJS部分の遅延読み込みをしていたにも関わらず、CLSが悪化していた理由はあらかじめ高さを指定して領域確保をしていなかった為。また、遅延読み込みコードについても変更しています。

functions.php

  • adsbygoogle.js?client=xxxxxxxxxのxxxxx部分に自分のAdsenseのコードの番号を入れる
  • これでメイン記事に対する遅延読み込みが可能に
手動広告貼り付け

サイドバーウィジェットやAdvanced Adsに登録しておくコードは前述同様にgoogleのJSを読み込む部分はカットし、尚且つあらかじめdivで高さを確保しておく

  • ca-pub-xxxxの部分が自分のAdsenseのコードの番号をいれる
  • data-ad-slotは自動広告ではなく手動広告の個別の広告ユニットに番号がついてるのでそれを入れる

もしもアフィリエイト

もしもアフィリエイトはWordpress貼り付けようのコードをかんたんリンクを使って作成できるのですが、Wordpress対応ではないコードを使ってしまっていたり、古い時代のコードのままにしてあったり、また画像の大きさを中以上にしておいたまま、コンテンツの冒頭に貼り付けるとCLSやLCPで悪化するのを確認しています。

また配信されてくる画像が最適化もされていない今どきjpgとなっている為、そこそこファイルサイズがあります。故に、冒頭ならば小サイズにとどめ、文中ならば中サイズを使うように工夫するとLazyloadも効くので僅かにですがCLSやLCPが改善します。

最初の画像の貼り付け位置

現在のWordpressのLazyloadの特徴なのか、最初の画像に対しては敢えて働かないようにしているようです。しかし、一方で冒頭に画像を貼り付けるとかならずLighthouseで指摘事項が入る。ということなので、目次の上の冒頭の文章内はアフィリエイト1つだけにとどめて、最初の1個目の画像を目次以下の最初のH2セクションの中に移動するだけで、わずかにですがCLSやLCPが改善します。

サイトの設定変更

サーバ設定変更

さくらのサーバのPHPに関して、8.1.24のモジュールモードに変更。すでに新サーバでPHP高速化が図られてるので、バージョン変更でどれだけ効果があるのかは不明ですが、様子見。

htaccessの設定変更

前述のプラグインでもgzip圧縮のコードが自動的に.htaccessに書き込まれたりするのですが、手動でこれを書くようにしてみました。ルートディレクトリ直下の.htaccessに対して行います。

function.phpの変更

全画像にloading属性を加える

なぜか自分のサイトは他のプラグインのせいなのか、画像を貼り付けてもloading="lazy"の属性値が書き加えられなくなっていたので(原因不明)、画像に対して属性値を加える項目を追加しました。WordpressのLazyloadを働かせるコードです。

jQuery読み込みをフッターに移動

前述にもあったフッターで読み込み系をもうちょっと増やしてみた。読み込み停止も増やして、特にjQuery系のLCP系悪化を改善してみた

Block Library読み込み停止

Pagespeed Insightを見てると毎回引っかかってくる項目の一つに「レンダリングを阻害してる項目」として、block-library.cssがある。これ、Wordpressが導入した悪名高いブロックエディタのライブラリで自分は大嫌いなので使っていない。さらにこれが読み込み阻害として検出されてる始末である。これを読み込み停止するコードを追加することでFCPが200msも大幅に改善する。

公式がこのようなライブラリを入れてるのはいかがなものだろうか?ということで、自分はAdvanced Editor Toolsで昔ながらで作ってるのでこのようなスピード悪化するだけのライブラリは排除する。

図:レンダリング阻害してる公式のCSS

テーマのfontawesome読み込み停止

Lightningというテーマを利用していますが、完全に余計な機能がてんこ盛りでちょっと困ってるのが「fontawesome」。標準で読み込みするようになっている。自分はウェブサイトにこれ完全に使わないので、事実Pagespeed Insightでもこれが使用していないCSSとして、なおかつレンダリングを阻害してる項目として出てきてる始末。

そこでこれを封じるために以下のコードを追加してみた。なおかつ対象のall.min.cssもリネームしておいて絶対に読み込まないように封じてみた。

jQueryの読み込みを変更

TBTの値をものすごく悪化させてるWordpress同梱のjQuery。できれば除去したいところですが、これを以下のコードで同梱されてるものから置き換えてみたところ、大幅にTBTの値が改善。GoogleのCDNから読み込んだほうが全然早い。今のWordpressは3.x系なのでそちらに置き換えても良いかもしれない。特に自分のレンタルサーバがそれほど高速ではない場合、CDNで読み込んだほうが全然早かったりするので。

ただ、管理画面以外でjQueryを必要とするかといったら、いらないと思うので自分は切っちゃってます。これでTBTの値がかなり改善する。ただし、jQueryを停止した場合、WP Fastest Cacheのキャッシュクリアが動かなくなったり、Lightningテーマだとサイドバー追従が動かなくなったりと影響がでる箇所も出てきます。このあたり自分で影響がない、あっても問題なしという場合は思い切って切って軽量化は判断になります。

DNSプリフェッチ

Adsenseの読み込み高速化のためにテストで以下のようなDNSプリフェッチ先読みを追加。しかし、今のところ、効果あるのかないのか。副作用もあるようなので、効果がなければ削除する予定。

プラグインの追加と削除

プラグインの断捨離を行いました。過去に断捨離したものを逆に復活させたり、新たに追加してみたり。

  • WP-Optimize - 停止。スピード面でちょっとな面がありつつもDBクリーン機能は使えるので残してある
  • SyntaxHighlighter Evolved  - Urvanov Syntax Highlighterをメインに使う事にしたので廃止
  • WP Fastest Cache - 復活。前者のWP-Optimizeよりも高速化できてる。エラーも出ていなかったので復活しました。
  • Advanced Ads - 追加。手動で一個ずつAdsenseコード貼り付けは厳しいのと、TinyMCEでも直接コードを入れられるので便利。
  • True Lazy Analytics - ExUnitやSimple SEOでは遅いので、GA4に対応したこともあって復活

SNSのソーシャルボタンの機能はExUnitのを使ってはいたものの、これらはちょっと別の手法で実現しようと検証中。オリジナルのLazy Loadを停止するコードはFunctions.phpに以下のコードを追記する

ただし、Lazy Load系はLazy Load - Optimize Imagesを導入すると、他のブログエントリーへのURLを貼り付けても、画像や説明が出なくなったりするので、よく吟味して導入したほうが良いです。すでに現在のWordpressは標準で画像のLazy LoadにもWebPの遅延読み込みに対応してるので、他のプラグインとバッティングする可能性やa3 Lazy Loadなどは不具合が出るので、いれるべきではないものもあります。

逆にLazy Loadプラグインの動作がLCPを悪化させるケースもあるようなので、要注意です。

CSSで調整

もしもアフィリエイトや利用してるテーマファイルの一部の画像や要素に対して高さの指定がなされていないものがあったので、以下の追加CSSを設定してあげて明示的に高さを指定するように追加しました。メディアクエリを利用し、PCの時とスマフォの時とでサイズを明示的に変更して指定することで、スペースをきちんと確保するようにしています。

もしもアフィリエイトのかんたんリンクで生成されたコードはそのままWordPressに貼り付けるとCLSの悪化に繋がります。こちらもGoogle Adsense同様に「<div class="adsense-wrapper "></div>」で括っておき、高さを明示的に指定する必要があります。テーマであるLightning特有の設定なども加えてCLS悪化につながってる項目を削っていきます。

※ちなみにChromeのLighthouseとPagespeed Insightでは後者のほうが厳し目の数値が出ます。

これにより、わずかですがCLSの悪化の原因となっていた外部からの画像の呼び出しに関してのCLS悪化を防ぐことが出来ました。もしもアフィリエイトのコードに対してはSearch Regexプラグインで一括でadsense-wrapperをつけるようにして記事を改変し置換しました。REST APIをfunctions.phpで封じてると使えないので注意が必要です。

2024年末チューニング

毎年年末はWordPressのいろいろなプラグインの見直しやチューニングを何故か行っていて、ここでその記録を残していますが、2024年末もサーバー側の変更なども相まっていくつかこれまでとは異なる作業を行いました。

2024年末は主に突然現れたサイトヘルスに出てきた項目を潰す為の作業を行っています。

MySQLやPHPのバージョンアップ

自身の利用してるレンタルサーバ側で、大幅な変更が生じたため、これに対応するためにレンタルサーバのコントロールパネルから以下の作業を行いました。

  • MySQLサーバが5.7から8.xに変更になったのでアップグレード作業を実施
  • PHPおよびPerlの使用バージョンをアップグレードを実施

これに合わせてWordPress側もMySQL項目のみ参照するDBのURLを変更を実施しました。本家サイトだと5.7→8.xによりDB参照スピードが2倍高速になったといったような文言がありますが、一方でクエリがあまり旨くない状態の場合逆に遅くなるといったような報告もあるため、体感ではわかりませんがパフォーマンスには大きく影響のある項目になります。

かといって5.7のまま継続するわけにもいかないので、WordPressを使ってる人は必ず8.x系に乗り換えましょう。乗り換えに当たって特に大きな障害は自分のケースでは発生していません。

永続オブジェクトキャッシュについて

WordPressのサイトヘルスの項目に突如として現れた「永続オブジェクトキャッシュを使用しましょう」の文言。以下の手法はなからずしも全部のレンタルサーバで使えるというわけではないものの、自分のケースでは使えたのでこの問題は解消しておきました。

手順としては以下のとおりです。

  1. プラグインとして「APCu Manager」を新規に追加し有効化する
  2. プラグインの設定を開き、Object Cacheという項目があるので、Activatedにチェックをする
  3. 他のチェックは外して変更を保存をクリックする

これだけです。体感的にはスピードアップした感じはありませんが、DBとApacheとのやり取りでだいぶ高速化されてるようです。

図:プラグインのみで解決可能

自動読み込みオプションについて

こちらもサイトヘルスに出てきた項目で、自動読み込みオプション項目が多すぎるので減らせといったような内容が出てきます。これ結構課題になってる問題で、行儀の悪い過去のプラグインなどの情報がそのまま残っていたり(本体はとっくにアンインストール済み)、余計なモジュールがロードされていたり・・・

アンインストールで本来除外されるべきなのに残ってるケースがあります。これらの情報を除外するにはwp_optionsというテーブルから1個ずつ検証して除外が必要ですが直接DB触って手作業でやるのはちょっと・・・ということで、こちらもプラグインを導入し、GUIでソレと思わしき不要なオプションを停止していきます(但し、やみくもに停止するとブログが壊れますので確かに停止して問題ないものだけを特定していく必要があります)。

  1. プラグインとして「AAA Option Optimizer」を導入し有効化する
  2. 左サイドバーのツールの中にあるOption Optimizerを開く
  3. Unused, but autoloadedのタブを開く
  4. 一番下にあるフィルタの項目でfiler by sourceをUnknownに変更する(WordPressの項目は弄らない)
  5. 出てきた内容にoptionがモジュール名で、show valueは何が設定されてるのか?を見ることが可能。モジュール名や内容からどのプラグインに関する内容なのかを推察
  6. 除外して問題ないと判断できたら、Remove Autoloadをクリックする
  7. これを出てくる項目全部に精査する

sizeが大きいほど、自動読み込み時にサイトのパフォーマンスに大きな影響を与えます。だからといって止めたら不味いものもあったりするので一概に止めて良いというわけでもないのが難しい所。代表的なのがfs_accounts。これは多くのプラグインでFreemiusというSDKが使ってるもので、止めると多数のプラグインに影響してしまいます。

とっくの昔に排除したJetpack関係の内容などが平然と残っていたりしたのでこういったものは躊躇なく削除しました。削除をすると元に戻せませんがremove autoloadならば後で戻せます。

図:Option Optimizerで精査する

その他

なぜスピードが重要なのか?

Pagespeed InsightやSearch consoleのエクスペリエンスでもいろいろな指標の結果が表示されていますがこれらが、直接Googleの検索結果の優先度に影響しているわけではありません。人気のあるコンテンツならば表示がモッサリしていても見てもらえるでしょう。しかし、SNSなどでも勘違いしてるSEO対策の人がいますが、「数値が直接GoogleのSEOに影響を及ぼすことはなくても、結果的にSEOには影響がある」ということ。

人が待てる時間というのは、とある計測では3秒と言われています。それ以上遅延する場合にはページから離脱したり、結果的に非参照リンクとして他のページからも参照されなくなったり。故に直接ではなくとも間接的にGoogleの検索結果の優先度に大きく影響していきます。表示スピードが遅くて良いことなど1つもありません。自分自身の行動を鑑みても、やはり遅いページは速攻で閉じてしまいます。

図:デスクトップ側は最適化しやすい

雑感

プラグイン排除によって、トップページに新着であったり、固定ページのYet Another Related Pluginによる関連リンクの表示、カスタム投稿タイプのエントリーの表示、スポンサーリンクの表示自体がなされていない。これらを後で装備し直そうと思う。

確かにVX All in one Expansion Unitプラグインはお手軽ではあるものの

  • それぞれの専門機能は専門のプラグインのほうがパフォーマンスが良い
  • Adsenseに至っては何の役にも立たないどころか、サイトパフォーマンスを落とす結果につながってる
  • 殆どの機能が専門プラグインで代替可能

という事で、手軽さの変わりに正直かなりウェブサイト運営に於いてはちょっと使えないなぁという印象(今回もカスタム投稿タイプの為だけに残している状態)。Jetpackの件もそうなんですが、多機能って正直いいことばかりじゃない。

※しかしここまで手間の掛かるチューニングしないとまともにスピード出せないWordPress。。ブロックエディタ装備よりもまず、こういった手間掛からず軽量化できるようにしてほしい。

関連リンク

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

日本語が含まれない投稿は無視されますのでご注意ください。(スパム対策)