zswap

提供: ArchWiki
2023年10月3日 (火) 13:52時点におけるAshMyzk (トーク | 投稿記録)による版 (同期)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動 検索に移動

関連記事

zswap は、スワップページ用の圧縮された RAM キャッシュを提供する、カーネルの機能です。ページをディスクにスワップアウトしてしまうのではなく、RAM 内のメモリプールに圧縮して保存します。プールが満タンになったり RAM が枯渇したりすると、最近使用されていない (LRU) ページを解凍して (まるでインターセプトされなかったかのように) ディスクに書き込みます。ページがスワップキャッシュへ解凍された後、プール内の圧縮された方を解放できます。

zram と異なる点は、zram に作成されたスワップはそれ自体が RAM 内のスワップデバイスとして働いてバッキングスワップデバイスを必要としないのに対し、zswapスワップデバイスと組み合わさって動作することです。

zswap を切り替える

すべての公式にサポートされているカーネルzswap はデフォルトで有効化されています。このことは、zgrep CONFIG_ZSWAP_DEFAULT_ON /proc/config.gz を実行することで確認できます。

zswap を実行時に無効化するには、以下のコマンドを実行してください:

# echo 0 > /sys/module/zswap/parameters/enabled

zswap を永続的に無効化するには、zswap.enabled=0カーネルパラメータに追加してください。

zswap のカスタマイズ

現在のパラメータ

zswap には、カスタマイズ可能なパラメーターがいくつかあります。現在の設定は、次を使用して表示できます:

$ grep -r . /sys/module/zswap/parameters/
/sys/module/zswap/parameters/same_filled_pages_enabled:Y
/sys/module/zswap/parameters/enabled:Y
/sys/module/zswap/parameters/max_pool_percent:20
/sys/module/zswap/parameters/compressor:zstd
/sys/module/zswap/parameters/non_same_filled_pages_enabled:Y
/sys/module/zswap/parameters/zpool:zsmalloc
/sys/module/zswap/parameters/exclusive_loads:N
/sys/module/zswap/parameters/accept_threshold_percent:90

様々なパラメーターの説明については、zswap のドキュメントを参照してください。

exclusive_loads パラメータ (現在 zswap のドキュメントには記述されていません) に関する詳細は Linux カーネルのソースコード内にあるこのコメントを見てください。

初期構成を示すブート時ロードメッセージは、次のコマンドで取得できます:

# dmesg | grep zswap:
[    0.317569] zswap: loaded using pool zstd/zsmalloc

パラメータの設定

sysfs の使用

各設定は、sysfs インターフェースを介して実行中に変更できます。例えば、compressor パラメータを変更するには:

# echo lz4 > /sys/module/zswap/parameters/compressor

カーネルブートパラメータの使用

パラメータの変更を永続化するには、対応するオプション (例えば zswap.compressor=lz4 など) をカーネルブートパラメータに追加する必要があります。したがって、上記のすべての設定を永続的に設定するには、次のカーネルパラメータを追加する必要があります:

zswap.enabled=1 zswap.compressor=lz4 zswap.max_pool_percent=20 zswap.zpool=z3fold

ブートパラメータを介して圧縮アルゴリズムを変更する場合、対応する圧縮モジュールがブートの早い段階でロードされていることを確認する必要があります (#圧縮アルゴリズム を参照)。

最大プールサイズ

メモリプールは事前に割り当てられません。使用可能な合計メモリのパーセンテージによる特定の制限まで (デフォルトでは合計 RAM の最大20%まで) 拡張できます。このしきい値に達すると、ページはプールからスワップデバイスに追い出されます。圧縮されたプールの最大サイズは、パラメーター max_pool_percent で制御されます。

圧縮メモリプールアロケータ

zpool パラメータは圧縮メモリプールの管理を制御します。

zbud データアロケーターを使用すると、2つの圧縮オブジェクトが1ページに格納され、圧縮率が2以下に制限されます。

z3fold アロケーターでは、ページごとに最大3つの圧縮オブジェクトを使用できます。z3fold の圧縮率は通常平均2.7ですが、zbud の圧縮率は1.7です。

タイプ z3foldzpool がデフォルトで作成されます。カーネルパラメータ zswap.zpool を使用して、起動時に別のアロケータを選択してください。データアロケータは、sysfs インターフェースを介して後の段階で変更することもできます。

より最近のカーネル (6.3.arch1-1 以降) では、zsmalloc アロケータが追加されています。これは、メモリが少ない状況で良く動作するとされており、より多くのメモリを削減します。

圧縮アルゴリズム

この記事またはセクションは情報が古くなっています。
理由: linux 6.3.arch1-1+ では CONFIG_ZSWAP_COMPRESSOR_DEFAULT="zstd" が設定されています。[1] (Discuss)

ページ圧縮の場合、zswap はカーネルの暗号化 API によって提供されるコンプレッサーモジュールを使用します。デフォルトでは lz4 圧縮アルゴリズムを使用しますが、これは起動時に zswap.compressor で変更できます。その他のオプションには、deflatelz4hclzolzo-rle842zstd があります。

実行中に sysfs を使用して圧縮を変更することに問題はありませんが、この場合、 zswaplz4 で開始し、後の段階で定義されたアルゴリズムに切り替わります。別のアルゴリズムで zswap をすぐに開始するには、これをカーネルのブートパラメータを介して設定し、対応するモジュールをカーネルによって早期にロードする必要があります。これは、次の手順に従って実行できます:

  1. 選んだコンプレッサーに関連するモジュールを mkinitcpio#MODULES 配列に追加する。
  2. mkinitcpio の設定を変更した後、RAM ディスク環境を再生成する。mkinitcpio#イメージ作成とアクティベーション を参照してください。
  3. カーネルパラメータzswap.compressor をあなたの選んだアルゴリズムに設定します。

次回の起動時に、#現在のパラメータ を参照して、zswap が要求されたコンプレッサーを使用するかどうかを確認してください。

Zswap の統計

zswap の統計を見るには、以下を実行してください:

# grep -r . /sys/kernel/debug/zswap
duplicate_entry:0
pool_limit_hit:13404213
pool_total_size:6184960 (pool size in total in pages)
reject_alloc_fail:5
reject_compress_poor:0
reject_kmemcache_fail:0
reject_reclaim_fail:13404213
stored_pages:4251 (pool size after compression)
written_back_pages:0

参照

翻訳ステータス: このページは en:Zswap の翻訳バージョンです。最後の翻訳日は 2023-10-03 です。もし英語版に 変更 があれば、翻訳の同期を手伝うことができます。