ホームページ >データベース >Redis >Redis で遅延削除 Lazy Free を使用する方法

Redis で遅延削除 Lazy Free を使用する方法

WBOY
WBOY転載
2023-05-26 23:37:041926ブラウズ

Use Lazy deletion Lazy free

キーの有効期限が切れた場合、または DEL delete コマンドが使用された場合、Redis はグローバル ハッシュ テーブルからオブジェクトを削除するだけでなく、オブジェクトによって割り当てられたメモリも解放します。大きなキーに遭遇した場合、メモリを解放するとメインスレッドがブロックされます。

この目的のために、Redis 4.0 では UNLINK コマンドが導入されました。このコマンドは、オブジェクト メモリを解放する操作をバイオ バックグラウンド スレッドに入れて実行します。これにより、メインスレッドのブロックが効果的に軽減されます。

Redis 6.0 ではさらに一歩進んで、Lazy-free 関連の構成が導入されています。構成が有効になると、「オブジェクトの解放」操作がキーの有効期限および DEL コマンド内で「非同期的に実行」されます。

void delCommand(client *c) {
    delGenericCommand(c,server.lazyfree_lazy_user_del);}void delGenericCommand(client *c, int lazy) {
    int numdel = 0, j;

    for (j = 1; j < c->argc; j++) {
        expireIfNeeded(c->db,c->argv[j]);
        // 开启 lazy free 则使用异步删除
        int deleted = lazy ? dbAsyncDelete(c->db,c->argv[j]) :
                              dbSyncDelete(c->db,c->argv[j]);
        ...
    }}

少なくとも Redis 6 にアップグレードし、Lazy-free を有効にすることをお勧めします。

以上がRedis で遅延削除 Lazy Free を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。