LiteSpeed Cacheプラグインの各設定値解説

mixhostなどのLiteSpeed WebサーバーでWordPressの高速化機能を最大限に活かすには、LiteSpeed Cacheプラグインを導入する必要があります。

そこで今回はLiteSpeed Cacheプラグインのインストール方法と、初心者にはわかりにくい設定画面の解説をお伝えします。

LiteSpeed Cacheとは

LiteSpeed Cacheは、LiteSpeed Webサーバーで使用できるキャッシュシステムです。

Webサーバーとは、サーバーの中の一つの機能で、パソコンのブラウザからホームページの表示要求を受け、パソコンに必要なデータを渡す処理をおこないます。

そのためWebサーバーの機能次第で、表示速度が大きく変わります。

WebサーバーのほとんどがApache(ロリポップ等)とNginx(エックスサーバー等)のどちらかが採用されています。

mixhostのように、LiteSpeed Webサーバーを導入しているレンタルサーバーは非常に少ないのです。

LiteSpeed Webサーバーを導入したのはmixhostが日本初
MixHost公式ページ

mixhostのサポートページによると、LiteSpeed Cacheは非常に高速かつ高性能で、キャッシュを有効にすることで数十倍から数百倍の高速化が可能だそうです。

LiteSpeed Webサーバーを利用しているなら、有効にしておかないともったいないですね。

キャッシュとは?

WordPressは、パソコンからページの表示要求を受けてから、データベースを検索してページを作成しています。
しかし同じページの表示要求を受け、毎回同じページを作成するのは非効率です。
表示直前のページを保存しておき、要求があったら、そのままパソコンに送り出した方が効率的です。
この仕組みをキャッシュと呼びます。

実際にはページだけでなく、ファイルやデータベースの呼び出しの一部を保存しておくなどの機能についても、キャッシュとして扱われます。

LiteSpeed Cacheプラグインのインストール

ではLiteSpeed Cacheのキャッシュ機能をWordPressで有効にするために、プラグインをインストールしましょう。

プラグイン > 新規追加 をクリック

プラグイン > 新規追加

キーワードに「LiteSpeed Cache」と入力

新規プラグイン キーワード入力

「今すぐインストール」をクリック

LiteSpeed Cacheプラグイン インストール

「有効化」をクリック

LiteSpeed Cacheプラグイン 有効

LiteSpeed Cacheプラグインのインストール完了!

注意

他にキャッシュプラグインを導入しているとLiteSpeed Cacheが正常に動作しません。
導入済みのプラグインを削除するか、LiteSpeed Cacheを使用しないで、そのまま利用してください。

LiteSpeed Cacheプラグインの設定

LiteSpeed Cache > 設定 をクリックして設定画面を開きます。

LiteSpeed Cacheプラグイン 設定メニュー

表示直後は、変更できるオプション設定が少ない状態です。

LiteSpeed Cacheプラグイン 高度非表示

高度なオプションを表示」をクリックすることで、全てのオプションが表示されます。

LiteSpeed Cacheプラグイン 高度表示

用語について

パージ:保存してあるキャッシュを破棄
TTL(Time to live):作成したキャッシュを破棄するまでの時間

各オプション値の説明

オプションは全部で12のタブに分かれていて、それぞれに詳細説明のページリンクが貼られています。

しかし専門的な説明でわかりにくいので、独自視点で解説してみます。

[1]全般

LiteSpeed Cacheのオン・オフ、キャッシュの有効期間を設定します。
ここで設定するのは、基本的にオン・オフの切り替えのみです。

LiteSpeed Cache を有効にする

LiteSpeed Cacheのオン・オフを切り替えます。
オフにすると、それまで保存してあるキャッシュが破棄(パージ)されます。

画面表示がおかしいと感じたら、一度無効にして、改善されるか確認をしてみてください。

デフォルトのパブリックキャッシュ TTL

公開したページのキャッシュが作成されて、一定の時間が経過するとキャッシュが破棄されます。
その時間を秒で指定します。
デフォルト604800秒=10080分=168時間=7日

デフォルトのプライベートキャッシュ TTL

非公開ページのTTLを秒で指定します。
デフォルト1800秒=30分

デフォルトのフロントページ TTL

TOPページのTTLを秒で指定します。
デフォルト604800秒=10080分=168時間=7日

デフォルトのフィード TTL

フィードのTTLを秒で指定します。30秒未満はキャッシュしません。
デフォルト1秒=キャッシュしない

デフォルトの404・403・500ページ TTL

404・403・500ページのTTLを秒で指定します。30秒未満はキャッシュしません。
デフォルト3600秒=60分=1時間

自動アップグレード

LiteSpeed Cacheプラグインを自動でアップグレードするか指定します。

[2]キャッシュ制御の設定

ここでは主に、キャッシュ対象を設定します。

ログインしたユーザーをキャッシュ

ログインユーザーごとにキャッシュを作成します。
会員登録しているユーザーのみに閲覧を許可しているサイトで意味がある機能です。
登録ユーザーが増えるほど効果が上がりますが、その分サーバーのディスクサイズを圧迫するので、状況を注意深く監視する必要があります。

コメントをキャッシュ

このオプション、よくわかりません(汗

説明文の日本語訳をそのまま掲載します。

このオプションは、ゲストのコメントをモデレートする必要があるWordPressオプションに役立ちます。 そのオプションが設定されている場合、このオプションはページのキャッシュバージョンを提供します。つまり、コメント投稿者にはモデレーションコメントが表示されません。 オフの場合、コメント投稿者はキャッシュから提供されません。

どうやら、詳細待ちというメッセージが表示されなくなるようだ。

REST API をキャッシュ

WordPress REST APIの要求をキャッシュします。

WordPress REST APIは、外部からWordPressへの投稿や記事参照を行える機能です。

ログインページをキャッシュ

ログイン画面をキャッシュします。

ログインページで画像認証など毎回表示が変わる場合、オフにした方がよさそうです。

favicon.ico をキャッシュ

favicon.icoが存在しない場合、余分な呼び出しがブラウザからおこなわれます。
意外と負担が多い処理なので、キャッシュをしておくべきです。
とりあえずONで!!

PHP リソースをキャッシュ

実行した結果同じ内容になるPHPのリソースをキャッシュします。
とりあえずONで!!

モバイルをキャッシュ

モバイル端末の種類ごとにキャッシュするかどうか指定します。
種類ごとに内容を変えたいとき、効果があります。
ただし、その分サーバーのディスクサイズを圧迫します。

モバイルユーザエージェントのリスト

モバイルかどうか判断するための、ユーザーエージェント文字列を指定します。

プライベートキャッシュ URIs

ここで指定した文字列とURLが一致した場合、プライベートキャッシュとして保存されます。

クエリ文字列を落とす

基本的に同じページでもクエリ文字列が異なれば別のキャッシュとして保存されます。
クエリ文字列を落とす(削除)することで、同じページとして扱います。

ただし、分析目的などで一般的に使用されるクエリ文字列は、自動で無視されます。

[3]パージ設定

ここではキャッシュを強制的に削除するタイミングを設定します。

アップグレード時にすべてをパージする

WordPressやテーマがアップグレードされたときに、保存されているキャッシュをすべて削除するかどうか指定します。
推奨はオンです。

公開 / 更新の自動パージルール

記事が公開されたり変更されたとき、連動して再生成するページを指定します。
影響を受けそうなものを指定するといいです。
よくわからないときは全てでも大丈夫。

スケジュールされたパージURL

特定の時刻でキャッシュを削除するページを指定します。
例えば外部ページの情報を決まった時間に取り込んでいるときなどに、使用します。

パージ予定時間

上で指定したURLをパージする時刻を指定します。

[4]設定を除外する

これまでの設定を、除外するパターンの設定をおこないます。

URIs を強制キャッシュする

他の設定にかかわらず、強制的にキャッシュするURLに一致する文字列を指定します。
正規表現での指定が可能です。

URIs をキャッシュしない

上記とは逆に、他の設定にかかわらずキャッシュさせたくないURLに一致する文字列を指定します。
毎回内容が変わるページを指定するといいでしょう。
正規表現での指定が可能です。

クエリ文字列をキャッシュしない

クエリ文字列単位でキャッシュさせたくないURLに一致する文字列を指定します。
例えばデバッグ中のページなどはキャッシュされると、テストに支障がでます。
クエリ文字でdebug=onなどを渡し、この欄で「debug」と指定することでキャッシュを無効化できます。
正規表現での指定が可能です。

カテゴリをキャッシュしない

キャッシュさせたくないカテゴリのスラッグを指定します。
設定保存時にカテゴリスラッグが存在していない場合、この欄から削除されます。
間違えて入力していないか、保存後に確認しましょう。

タグをキャッシュしない

キャッシュさせたくないタグのスラッグを指定します。
こちらも設定保存時にスラッグが存在していない場合、この欄から削除されます。
保存後に確認しましょう。

クッキー をキャッシュしない

ページにこの欄で指定したクッキーが含まれている場合、そのページをキャッシュしません。
安易に設定すると、サイト全体がキャッシュ対象から除外されることもあるので、注意しましょう。

ユーザーエージェントをキャッシュしない

ユーザーエージェントの内容が、この欄で指定した文字列と一致した場合、キャッシュが存在していても、ページ生成されます。
検索クローラーに常に新しいページを提供するのに有効…かもしれません。

ロールをキャッシュしない

WordPress上での管理者などのロールごとに、キャッシュされたページを表示するかどうかを指定できます。

[5]最適化の設定

CSSファイルとJavascriptファイルを最適化する設定をおこないます。

CSS 圧縮化

CSSファイルから余分な空白や改行を削除します。
これにより、転送量を削減できます。

CSS 結合

複数のCSSファイルを一つのファイルにまとめます。
これにより、ブラウザからの呼び出しが一回で済みます。

ただし複数のファイルに同じ内容のスタイル設定がある場合、後の内容が優先されます。
そのため、結合によりブラウザ上での表示が変わってしまうことがあります。

CSS HTTP/2 プッシュ

ブラウザ(クライアント)から要求される前に、CSSファイルを送り付けます。
クライアントは、要求してファイルが送られてくるまでの時間が不要になるので、速く表示することができます。

JS 圧縮化

Javascriptファイルから余分な空白や改行を削除します。
これにより、転送量を削減できます。

JS 結合

複数のJavascriptファイルを一つのファイルにまとめます。
これにより、ブラウザからの呼び出しが一回で済みます。

こちらもCSSと同じように、誤動作などの副作用がおこる可能性があります。

JS HTTP/2 プッシュ

ブラウザ(クライアント)から要求される前に、Javascriptファイルを送り付けます。
クライアントは、要求してファイルが送られてくるまでの時間が不要になるので、速く表示することができます。

CSS/JS キャッシュ TTL

キャッシュされたCSSとJavascriptが破棄されて再生成されるまでの時間を指定します。
デフォルトは604800秒=10080分=168時間=7日です。

CSSやJavascriptを変更した場合の挙動がわかりません。
念のため、管理メニューでパージしたほうがいいかもしれません。

HTML・インライン CSS・インライン JS 圧縮化

HTML内から画面表示と関連しない空白や改行、コメントが削除されます。
※インライン CSS・インライン JSは、HTML内に記述されたCSSとJavascriptです。

CSSを非同期ロード

オフの場合、ブラウザはCSSを読み込んでから画面を表示します。
オンの場合は、CSSの読み込みと画像表示が同時におこなわれます。
そのため、一時的に画面表示が乱れます。

クリティカル CSS を生成

CSS非同期ロードでの初期画面の乱れを緩和するために、必要なスタイルを抽出したクリティカルCSSを作成します。
生成はLiteSpeedのリモートCCSSサーバーにておこなわれたあと、レンタルサーバーにキャッシュされます。
そのため、ccss.api.litespeedtech.comからのアクセスをブロックしてはいけません。

またクリティカルCSSは最初にページを表示するときに作成されるので、そのときの閲覧者は乱れた画像が表示される可能性があります。

バックグラウンドでクリティカル CSS を生成する

オフにした場合、クリティカルCSSが作成されてから、ブラウザにコンテンツが送信されます。
つまり表示までの時間が非常に遅くなります。

オン推奨です。

別々のCCSSキャッシュポストタイプ

基本的に一つの投稿タイプにつき、ひとつのクリティカルCSSが生成されます。

この欄に投稿タイプを入力すると、ページごとにクリティカルCSSが生成されます。

個別のCCSSキャッシュURI

この欄にURLの一部を入力すると、一致するページに対してクリティカルCSSが生成されます。

上の投稿タイプを使用するよりも、こちらを使用したほうが安全だと思います。

インライン CSS非同期ライブラリ

非同期のCSSライブラリをhtmlデータ内に挿入します。
とはいえ、全てのCSSがインライン展開されるわけではないようです。

JS Deferredをロード

scriptタグにDeferred属性を付加します。
これにより、外部スクリプトが非同期で読み込まれます。

非同期での読み込みは、読み込む順番を制御できません。
依存関係があるスクリプトファイルにおいてこれは致命的で、ほとんどのケースでエラーとなります。

そのため、このオプションは非推奨です。
オフにしておきましょう。

JQueryを除外する

JSについての設定から、JQueryを除外します。
オン推奨です。

DNS プリフェッチ

画面遷移する可能性が高いドメインのDNS(IPアドレス)を、先に検索しておくことで、ページ移動を素早くおこなえるようにします。

サイドバーなどに設置した、重要な外部サイトのドメインを指定しておくといいかもしれません。

コメントを削除します

余分なコメントを削除して、転送時間を削減します。

[6]チューニングの設定

[5]の最適化設定をさらに詳しく設定します。

CSS 結合の優先度

外部のCSSファイルと、[5]の最適化で結合したCSSファイルの読み込む順番を指定します。

オン:結合したCSSファイルを先に読み込む

オフ:外部のCSSファイルを先に読み込む

CSS 除外

[5]のCSSに関する設定から除外するCSSファイルを指定します。

JS 結合の優先度

外部のJSファイルと、[5]の最適化で結合したJSファイルの読み込む順番を指定します。

オン:結合したJSファイルを先に読み込む

オフ:外部のJSファイルを先に読み込む

JS 除外

[5]のJSに関する設定から除外するJSファイルを指定します。

結合されたファイルの最大サイズ

結合後の最大ファイルサイズを指定します。
最大ファイルサイズを超える場合、複数のファイルに分割されます。

基本的にはファイル数が少ない方がページスコアがよくなりますが、ファイルサイズが大きくなるにつれて必要なメモリサイズが増えます。
LiteSpeed Cacheの技術者は1.2MBが最適だと考えているそうです。

クエリ文字列を削除

JSやCSSファイルのURLから、クエリ文字列を削除します。

通常、JSやCSSファイルはブラウザでキャッシュされます。
しかし一部のブラウザでは、クエリ文字列があるとキャッシュされないことがあるためです。

Google フォントを非同期に読み込む

Googleフォントはとても重いです。
他のCSSは非同期にしていなくても、Googleフォントだけは非同期にしておいたほうがいいです。

よってオン推奨です。
Googleフォントを使っているかどうかわからないなら、オンにしておきましょう。

Googleフォントを削除

Googleフォントの読み込みを禁止します。
そもそも重いならいらない、という人はオンにします。
ただし、表示されない文字が出てくる可能性があるので注意。

クリティカル CSS ルール

自動生成されるクリティカルCSSに、追加するスタイルを記述します。

JS 繰延を除外

[5]で「JS Deferredをロード」をオンにしたとき、対象外とするJSファイルのURLを指定します。

WordPress 文字を削除

オンにすると、WordPressの絵文字表示機能に必要なJavascriptを削除します。
最近のブラウザは、この機能がなくても問題ないようです。

除外 URI

[5]の最適化から除外したいURLを指定します。

役割除外

[5]の最適化を行わないロールを指定します。

[7]メディア設定

主にイメージ画像(jpeg,png,webp)のブラウザ表示と、最適化について設定を行います。

画像 遅延読み込み

画面上に表示されている画像のみ読み込みます。
これにより、サイトの表示速度を向上できます。

次のCSSを使用することで、画像をフェードイン(ふわっと表示)させることができます。

img[data-lazyloaded]{
	opacity: 0;
}
img.litespeed-loaded{
	-webkit-transition: opacity .5s linear 0.2s;
	-moz-transition: opacity .5s linear 0.2s;
	transition: opacity .5s linear 0.2s;
	opacity: 1;
}
画像 遅延読み込みを除外

遅延表示対象外とする、画像のURLを指定します。
URLの一部だけでもOKです。

画像遅延読み込みクラス名を除きます

遅延表示対象外とする、クラス名を指定します。
クラス名の一部だけでもOKです。

画像 遅延読み込みプレースフォルダ

画像読み込み前に表示する画像を指定します。
デフォルトは灰色画像です。

・・・という形式(base64)で指定します。

例えば、次のような画像の場合、
Now Loading

base64では、次のような表記になります。



一見便利そうな機能ですが、全ての画像タグにこの文字列が付加されるので、データサイズを極端に増やすことになります。
あまりおススメできない機能です。

応答プレースホルダ

元画像と同じサイズで、プレースフォルダの画像を作成します。
imgタグに、高さ(height)と幅(width)が指定されているときのみ有効です。

応答プレースホルダ背景色

応答プレースホルダの背景色を指定します。

バックグラウンドで応答プレースホルダを生成する

応答プレースホルダは、ページに最初にアクセスされたときに生成されます。
このオプションがオフの場合、応答プレースホルダの生成が完了してから、ページデータがクライアントに配信されます。
そのため、最初のアクセスでの画面表示は、通常より多くの時間がかかります。

Iframes 遅延読み込み

Iframeが画面外の場合、読み込みを行いません。

インラインレイジーロードイメージライブラリ

画像の遅延読み込みに必要なJavascriptファイルを、HTML内にインライン展開します。
同じファイル内に組み込まれるため、動作しない確率が減ります。

自動的に最適化する

画像の最適化を行います。
1200クレジットのアカウントでのみ機能するという制限があります。

1200クレジットとは何なのかは不明です。
EWWW Image Optimizerプラグインなどを入れてしまった方が、手っ取り早そうです。

なお、画像データ圧縮なら、こちらのツールを使ってみてください!(宣伝)
アフィリエイター向け画像軽量化ツール

最適化 Cron

この機能をオフにした場合、サーバーで最適化された画像を手動で取得する必要があります。

オリジナル画像の最適化

最適化前の画像を、別名で保存します。

オリジナルバックアップを削除する

最適化終了後に、バックアップを削除します。

WebP のバージョンを最適化する

最適化と同時に、WebP形式の画像ファイルを作成します。

可逆最適化

品質の劣化がない方式で画像を圧縮します。
ただし、ファイルサイズはあまり小さくなりません。

EXIF / XMPデータを保存する

画像内の画像表示に必要がないデータ(撮影場所など)を維持します。

WebP 画像への置換

WebP形式の画像を表示できるブラウザから呼び出された場合、他の形式の代わりにWebP形式を送信します。
ここでオンにした場合、実際に表示するには、画像ごとにメディアライブラリで、WebPの有効化を行う必要があります。

めんどくさい!

WebP 属性を置換する

指定されたタグ属性と一致するものを、WebPに変換します。

WebP の 特別な srcset

WordPressの標準的な処理外でsrcset要素を作成して、その要素に対してWebP置換をしたい場合、オンにします。

[8]CDN設定

CDN(Content Delivery Network)とは、コンテンツの全てまたは一部を、サーバーとは別の場所に保存しておき、状況に応じてコンテンツの取得先を変えることができるネットワークのことです。

ブラウザからのアクセスを分散することで負荷軽減となり、サーバーダウンの確率を減らすことができます。

CDN を有効にする

CDNを使用する場合、オンにします。
ただしCloudflareを使用する場合はオフにして、CloudflareのAPIを使用します。

CDN マッピング

CDNサーバーの、配信設定を行います。

画像・CSS・js毎に配信元を変更する場合、「+」ボタンを押して、入力欄を増やしてください。

CDN URL:CDNとして使用するサーバーへのパスを入力します。

画像を含める:全ての画像をCDNから配信します。

CSS を含める:全てのCSSファイルをCDNから配信します。

JS 含める:全てのjsファイルをCDNから配信します。

ファイルの種類を含める:CDNから配信するファイルのタイプを指定します。phpなどの動的に作成されるファイルは指定できません。画像などの静的ファイルである必要があります。

元の URL

CDN経由でサイトURLが必要な場合、この値が使用されます。
基本的に、変更する必要はありません。

含まれるディレクトリ

指定されたディレクトリ内のファイルが、CDNの対象となります。

除外パス

CDNの対象外としたいファイルのパスを指定します。

JQuery をリモート読み込み

JQueryをサイト内からでなく、他のCDNから読み込むように変更します。
選択できるのは、GoogleとCdnjsです。

Quic Cloud API

Quic Cloudを使用する場合オンにし、メールアドレスとユーザーAPIキーを入力します。

Cloudflare API

Cloudflareを使用する場合オンにし、メールアドレスとグローバル API キー・ドメインを入力します。

管理 > CDN でその他の設定を行えます。

[9]ESI設定

ESIとは、一つのコンテンツをキャッシュする部分とキャッシュしない部分を明示的に分けることで、ページ作成を効率化できます。

ただし、プログラム的な作りこみが必要なため、一般的には使用できません。

ESIを有効にする

ログインユーザーに対して、 管理バー・コメント・コメントフォーム・最近の投稿ウィジェット・ 最近のコメントウィジェットがESIとして作成されます。

管理バーをキャッシュ

管理バーをキャッシュします。

コメントフォームをキャッシュ

コメントフォームをキャッシュをキャッシュします。

グループを変更

0以外を設定すると、番号ごとに個別のキャッシュが作成されます。

ESIタブに入っていますが、通常のキャッシュとしての動作で、ESIの機能ではないそうです。

まとめ

他に、[A]高度、[B]デバッグ、[C]クローラーがありますが、あまり変更するものではないので、ここまでとします。

ここで紹介したオプションを変更してみて、速度が向上するかどうか試してみてください。