ホームページ >データベース >Redis >Redis の種類とエンコーディングの原則と使用法は何ですか?

Redis の種類とエンコーディングの原則と使用法は何ですか?

王林
王林転載
2023-05-29 16:21:03965ブラウズ

    摘要

    Redis是一款开源的高性能key-value数据库,广泛应用于各种场景。在Redis中,数据类型(type)和编码(encoding) 是非常重要的概念。本篇博客将详细介绍Redis支持的数据类型以及相应的编码方式和底层实现原理。

    要查看Redis某个key的内部编码,可以使用Redis命令OBJECT ENCODING key。其中,key是你想要查询的键名。例如,如果你想要查询名为mykey的键的内部编码,可以执行以下命令:

    127.0.0.1:6379> object encoding mykey  // 查看某个Redis键值的编码

    redisObject

    在 Redis 中,redisObject 是 Redis 中最基本的数据结构之一。redisObject 用于表示 Redis 中的键值对中的值,它可以是字符串、整数、列表、哈希表等任意一种 Redis 数据类型。

    redisObject 的定义如下:

    typedef struct redisObject {
    
        // 类型
        unsigned type:4;
    
        // 编码方式
        unsigned encoding:4;
    
        // 引用计数
        int refcount;
    
        // 指向实际值的指针
        void *ptr;
    
    } robj;
    • type:表示 redisObject 的类型。

    • encoding:表示 redisObject 的编码方式。

    • refcount:表示当前 redisObject 被引用的次数。

    • ptr: ptr字段则是一个指针,指向实际的 Redis 对象。

    Redis源码encoding取值有如下几种:

    #define OBJ_ENCODING_RAW 0        /* Raw representation */
    #define OBJ_ENCODING_INT 1        /* Encoded as integer */
    #define OBJ_ENCODING_HT 2         /* Encoded as hash table */
    #define OBJ_ENCODING_ZIPMAP 3     /* Encoded as zipmap */
    #define OBJ_ENCODING_LINKEDLIST 4 /* No longer used: old list encoding. */
    #define OBJ_ENCODING_ZIPLIST 5    /* Encoded as ziplist */
    #define OBJ_ENCODING_INTSET 6     /* Encoded as intset */
    #define OBJ_ENCODING_SKIPLIST 7   /* Encoded as skiplist */
    #define OBJ_ENCODING_EMBSTR 8     /* Embedded sds string encoding */
    #define OBJ_ENCODING_QUICKLIST 9  /* Encoded as linked list of ziplists */

    类型与编码介绍

    Redis支持五种主要的数据类型:字符串(string)、列表(list)、集合(set)、有序集合(sorted set)和哈希(hash)。每种数据类型都有对应的编码方式。

    数据类型与编码方式总览如下:

    数据类型 编码方式
    字符串 int、embstr、raw
    哈希表 ziplist、hashtable
    列表 ziplist、linkedlist、quicklist
    集合 intset、hashtable
    有序集合 ziplist、skiplist

    String

    String は Redis の最も基本的なデータ型で、通常はテキストまたはバイナリ データを保存するために使用されます。 Redis は 2 つのエンコード方式をサポートしています。

    • Redis では、文字列が整数として表現できる場合、文字列は整数に変換され、int エンコードを使用して保存されます。 int エンコードの利点は、ストレージ容量が小さく、操作効率が高いことです。欠点は、整数のみを保存でき、文字列操作をサポートしていないことです。

    • embstr(embstr-encoded string): 44 バイト未満の長さの文字列を保存します。文字列が比較的短い場合は、このエンコード方法を使用して保存します。メモリ使用量を削減します。

    • raw(生エンコードされた文字列):

      44 バイトを超える文字列を保存する. 文字列が比較的長い場合、このエンコード方法を使用して文字列が保存されます。

    リスト

    リストは、要素を追加、変更、削除できる順序付けされた文字列のコレクションです。 Redis は 3 つのエンコード方式をサポートしています:

    • ziplist: Redis3.2 バージョンより前、

      List 内の各文字列の長さが 64 バイト未満であり、リスト内の文字列の長さが 64 バイト未満の場合要素数が 512 未満の場合、List オブジェクトは ziplist エンコードを使用し、それ以外の場合はリンクリスト エンコードが使用されます。 ziplist は、メモリを節約するコンパクトな圧縮リスト構造です。小さなリストに適しています。

    • Linkedlist は、リンク リスト構造を通じてあらゆるサイズのリストをサポートするデータ構造の一種です。ただし、リストの長さが増加するにつれて、そのメモリ使用量も増加します。

    • クイックリスト:

      Redis 3.2 バージョン で導入されたクイックリストは、複数のジップリストで構成されるリスト構造であり、パフォーマンスを確保するだけでなく、メモリも節約できます。大規模なリストに適しています。

    コレクション

    コレクションは、要素の追加、削除、クエリをサポートする一連の順序なしの文字列コレクションです。 Redis は 2 つのエンコード方式をサポートしています:

    • intset:

      コレクション内の要素がすべて整数の場合、Redis は intset エンコードを使用して を格納します。 intset エンコーディングの利点は、ストレージ容量が小さく、操作効率が高いことです。

    • ハッシュテーブル:

      コレクション内の要素に文字列が含まれている場合、Redis はハッシュテーブル エンコーディングを使用して を保存します。ハッシュテーブル エンコーディングの利点は、あらゆるタイプの要素を格納でき、文字列操作をサポートしていることです。欠点は、保管スペースが比較的大きく、作業効率が比較的低いことです。

    順序付きセット

    順序なしの文字列コレクションにはスコアが割り当てられるため、スコアに従って並べ替えて順序付きセットを形成できます。 Redis は 2 つのエンコード方法をサポートしています:

    • ziplist:

      保存する要素は 128 未満で、すべての要素のサイズは 64 バイト未満です。ziplist エンコードを使用します。、ziplist は順序付けられた小規模なコレクションに適した、コンパクトな圧縮リスト構造。

    • skiplist: Skiplist は、高速なクエリと並べ替えをサポートするスキップ リスト構造です。大規模な注文コレクションに適しています。

    ハッシュ テーブル

    ハッシュ テーブルは、各キーが値に関連付けられたキーと値のペアのコレクションです。 Redis は 2 つのエンコード方式をサポートしています:

    • ziplist:

      ハッシュ オブジェクトに格納されるすべてのキー値の文字列長は 64 バイト未満であり、キーと値のペアの数はが 512 未満の場合、Redis は ziplist エンコーディングを使用して保存します。ジップリスト エンコード方式の利点は、保存スペースが小さく、操作効率が高いことです。欠点は、高速キー検索操作がサポートされていないことです。

    • 上記の条件に加えて、Redis はハッシュ テーブル エンコーディングを使用して保存します。ハッシュテーブル エンコーディングの利点は、高速なキー検索操作をサポートしていることです。欠点は、保管スペースが比較的大きく、作業効率が比較的低いことです。

    型とエンコードの基本原則

    Redis でサポートされるデータ型とエンコード方法を理解した後、それらの基本的な実装原則を見てみましょう。

    エンコーディング変換

    Redis では、各キーと値のペアには型識別子があり、キーと値のペアに格納されているデータ型を示すために使用されます。キーを操作するとき、Redis はキーの現在のエンコーディングと操作に必要なエンコーディングに基づいてキーと値のペアをエンコードします。

    たとえば、文字列にコンテンツを追加するとき、文字列の現在のエンコード方式が raw であるが、新しいコンテンツを embstr エンコードを使用して保存できる場合、Redis は文字列をエンコードします。メソッドは次から変換されます。 raw から embstr まで。

    データ構造

    Redis は、エンコード方法に限定されるものではなく、さまざまな従来のデータ構造を使用してさまざまなデータ型を実装します。たとえば、Redis リストとハッシュ テーブルは、リンク リスト構造を使用して実装されます。スキップ リストは、順序付けされたコレクションで使用される効率的なデータ構造です。

    これらのデータ構造は、さまざまなシナリオでのアプリケーションのニーズを満たすために慎重に設計され、最適化されています。たとえば、リンク リスト構造は要素を頻繁に追加および削除する必要がある状況に適していますが、スキップ リスト構造は並べ替えや検索操作に適しています。

    以上がRedis の種類とエンコーディングの原則と使用法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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