目次
redis の 3 つの拡張データ型
時系列データを Redis に保存するにはどうすればよいですか?
ホームページ データベース Redis Redisのデータ構造知識を画像と文章で詳しく解説

Redisのデータ構造知識を画像と文章で詳しく解説

Apr 01, 2022 pm 01:31 PM
redis

この記事では、Redis に関する関連知識を提供します。主に、文字列、リスト、ハッシュ、順序セットなどのデータ構造に関する関連問題を紹介します。内容は、皆様のお役に立てれば幸いです。

Redisのデータ構造知識を画像と文章で詳しく解説

推奨学習: Redis 学習チュートリアル

Redis データ構造: String (文字列)、List (リスト)、ハッシュ (ハッシュ) )、セット (セット)、短縮セット (順序セット)

基礎となるデータ構造: 単純な動的文字列、二重リンク リスト、圧縮リスト、ハッシュ テーブル、スキップ リスト、整数配列
Redisのデータ構造知識を画像と文章で詳しく解説
1. ハッシュ テーブル: ハッシュ テーブルは実際には配列であり、配列内の各要素はハッシュ バケットと呼ばれます。 Redisのデータ構造知識を画像と文章で詳しく解説
ハッシュの競合と再ハッシュにより、操作がブロックされる可能性があります。
redis がハッシュの競合を解決する方法はチェーン ハッシュですが、rehash は既存のハッシュ バケットの数を増やすことです。
Redisのデータ構造知識を画像と文章で詳しく解説
再ハッシュ操作の手順: 1. より大きな領域をハッシュ テーブルに割り当てます (たとえば、現在のハッシュ テーブルの 2 倍のサイズ)
2. ハッシュ テーブル 1 のデータを再マップし、それを次の場所にコピーします。ハッシュ テーブル 2
3. ハッシュ テーブル 1
の領域を解放します。 2 番目のステップでは、大量のデータ コピー操作が必要です。ハッシュ テーブル 1 のすべてのデータを一度に移行すると、スレッド ブロッキングが発生します。他のリクエストは処理できません。この問題を回避するために、redis はプログレッシブ リハッシュを使用します。
Redisのデータ構造知識を画像と文章で詳しく解説
整数配列と二重リンク リストの複雑さは O(N)
です。圧縮されたリストのヘッダーには 3 つのデータが含まれます。 length、リストの末尾のオフセットとリスト内のエントリの数
圧縮リストの末尾には、リストの末尾を表す要素 zlend もあります。Redisのデータ構造知識を画像と文章で詳しく解説
リストをスキップします。順序付きリンク リストは要素を 1 つずつ検索することしかできませんが、ジャンプ リストはリンク リストに基づいてマルチレベルのインデックスが追加され、インデックス位置での複数のジャンプを通じてデータを迅速に配置できます。 Redisのデータ構造知識を画像と文章で詳しく解説 次の 5 つの構造の時間計算量

Redisのデータ構造知識を画像と文章で詳しく解説

String 型

String 型はすべてのシナリオに適しているわけではありません。消費量が多いという明らかな欠点があります。データを保存するときのメモリ容量。 String 型では、データ長、スペース使用量、その他の情報を記録するために追加のメモリ スペースが必要となるため、この情報はメタデータとも呼ばれます。

保存データに文字が含まれる場合、文字列は単純な動的文字列 SDS 構造を使用して保存されます

Redisのデータ構造知識を画像と文章で詳しく解説 len は buf の使用長です alloc は実際に割り当てられた buf の長さです
なぜなら、redis多くのデータ型があり、異なるデータ型には記録する同じメタデータがあるため、redis は RedisObject 構造を使用してこれらのメタデータを均一に記録します。

Redisのデータ構造知識を画像と文章で詳しく解説 Long 型を保存する場合、RedisObject ポインターに値を直接整数データに設定できるため、整数を指すために追加のポインターが必要なくなり、ポインターのスペース オーバーヘッドが節約されます。
保存された文字列が 44 バイト未満の場合、sds とメタデータは embstr エンコーディングと呼ばれる連続メモリ領域に割り当てられます。
保存された文字列が 44 バイトより大きい場合、SDS とメタデータは embstr エンコーディングと呼ばれ、別々に保存されます。生のエンコーディング

Redisのデータ構造知識を画像と文章で詳しく解説
さらに、redis はグローバル ハッシュ テーブルを使用してすべてのキーと値のペアを保存します。ハッシュ テーブル内の各項目は、キーと値のペアを指すために使用される dictEntry 構造です。キー値が表示されます。次は 24 バイトを使用しますが、実際には 32 バイトを占有します。これは、jemalloc がメモリを割り当てるときに、N より大きいが N に最も近い 2 のべき乗を、バイト数に応じて見つけるためです。スペースを申請することで、頻繁な割り当ての数を減らすことができます。
Redisのデータ構造知識を画像と文章で詳しく解説
メモリを節約するにはどのようなデータ構造を使用できますか?
圧縮リスト: zlbytes はリストの長さを表し、zltail はリストの末尾オフセットを表し、zllen はリスト内のエントリの数を表し、zlend はリストの終わりを表し、perv_len はリストの長さを表します。前のエントリでは、encoding はエンコード方法を表し、len はそれ自体の長さを表し、キーは実際に格納されているデータです。 Redis は、圧縮リストに基づいてリスト、ハッシュ、ソート セットを実装します。

Redisのデータ構造知識を画像と文章で詳しく解説
セット タイプを使用して単一値のキーと値のペアを保存するにはどうすればよいですか?
単一値のキーと値のペアを保存する場合、単一値の値を 2 つの部分に分割するハッシュの 2 番目のエンコーディングを使用できます。最初の部分はハッシュ キーとして使用され、後半の部分はハッシュ キーとして使用されます。

以图片 ID 1101000060 和图片存储对象 ID 3302000080 为例,我们可以把图片 ID 的前 7 位(1101000)作为 Hash 类型的键,把图片 ID 的最后 3 位(060)和图片存储对象 ID 分别作为 Hash 类型值中的 key 和 value。127.0.0.1:6379> info memory# Memoryused_memory:1039120127.0.0.1:6379> hset 1101000 060 3302000080(integer) 1127.0.0.1:6379> info memory# Memoryused_memory:1039136
ログイン後にコピー

ハッシュ タイプには 2 つの基本的な実装構造があります: 1. 圧縮リスト 2. ハッシュ テーブル
ハッシュ リストには 2 つのしきい値があります。これら 2 つのしきい値を超えると、圧縮リストからハッシュ テーブルに変換されます。
hash-max-ziplist-entries は、圧縮リストに保存するときに設定されたハッシュ リストの要素の最大数を示します。
hash-max-ziplist-value は、圧縮リストに保存する場合のハッシュ セットの 1 つの要素の最大長

統計モードの設定
1. 統計の集計
2. 統計の並べ替え
3.バイナリ状態統計
4. カーディナリティ統計

redis の 3 つの拡張データ型

1.Bitmap:
2.HyperLogLog
3.GEO:
LBS アプリケーションの GEO データ型
GEO の基礎となる構造は、ソート セットに基づいて実装されます。ソート セットは、要素の重みに従ってソートでき、範囲クエリをサポートします。Redisのデータ構造知識を画像と文章で詳しく解説
重みスコアのsorted Set は浮動小数点数 (float 型) ですが、経度と緯度は 2 つの数値であるため、GeoHash エンコードを使用する必要があります。
GeoHash エンコードは、「2 分割間隔、間隔エンコード」方式で実行されます。
最初に経度と緯度をコード化された形式に変換し、次に交差を実行します
Redisのデータ構造知識を画像と文章で詳しく解説
実際、交差の目的は次の図に示す概念です。実際に 2 次元の場所を特定できます。空間内の正方形では、ソート セット範囲クエリを使用して同様のコーディング値を取得します。実際の地理空間では、これらは隣接する正方形でもあります。たとえば、1110011101 と 1111011101 は空間内で隣接しています。
Redisのデータ構造知識を画像と文章で詳しく解説
ただし、コードは隣接していても、実際には正方形が隣接していない場合もあります。したがって、この状況が発生するのを避けるために、特定の経度と緯度の周囲の 4 つまたは 8 つの正方形を同時にクエリすることができます。 Redisのデータ構造知識を画像と文章で詳しく解説 GEO タイプを使用する場合、よく使用する 2 つのコマンドは GEOADD と GEORADIUS です。

GEOADD: 一連の経度と緯度の情報および対応する ID を GEO タイプのコレクションに記録するために使用されます。

使用法: 車両 ID が 33 で、緯度と経度の位置が (116.034579, 39.030452) であるとします。GEO コレクションを使用して、すべての車両の緯度と経度を保存できます。コレクション キーは、cars:locations です。以下のコマンドを実行するだけで、ID 番号 33 の車両の現在の経度と緯度の位置が GEO に保存されます。

GEOADD cars:locations 116.034579 39.030452 33
ログイン後にコピー

GEORADIUS: 入力経度および緯度の位置に基づいて、この経度および緯度を中心とする特定の範囲内の他の要素をクエリします
データ型をカスタマイズするにはどうすればよいですか?

redis の基本的なオブジェクト構造には、type、encoding、lru、refcount、*ptr

NewTypeObject という名前のデータ構造を開発します。具体的には、次の 4 つの手順があります
Redisのデータ構造知識を画像と文章で詳しく解説

時系列データを Redis に保存するにはどうすればよいですか?

1. ハッシュとソート セットに基づいた保存: 2 つのデータ構造に基づいてクエリを実行する必要があるのはなぜですか?
ハッシュ型は時系列単一キークエリのニーズを満たす高速な単一キークエリを実現できます Redisのデータ構造知識を画像と文章で詳しく解説
ただし、ハッシュ型には範囲クエリをサポートしていないという欠点があります。タイムスタンプ範囲クエリをサポートするには、要素の重みスコアに従ってソートするため、Through Sorted Set が必要です。 Redisのデータ構造知識を画像と文章で詳しく解説
では、これら 2 つの操作のアトミック性を確保するにはどうすればよいでしょうか。
MULTI と EXEC の 2 つのコマンドを渡す必要があります:
MULTI は開始を意味します。このコマンドを受信すると、redis はコマンドをキューに入れます。
EXEC は終了を意味します。このコマンドを受信した後、開始されます。コマンドRedisのデータ構造知識を画像と文章で詳しく解説
ただし、ハッシュとソート セットを使用する場合は、範囲クエリのみがサポートされ、集計計算はサポートされません。クライアント上で集計計算を実行すると、大量のネットワーク送信が発生します。したがって、RedisTimeSeries を通じて Redis 上で集計計算を実行できます。

推奨学習: Redis 学習チュートリアル

以上がRedisのデータ構造知識を画像と文章で詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Windows 11 10.0.22000.100 のインストール時の 0x80242008 エラーの解決策 Windows 11 10.0.22000.100 のインストール時の 0x80242008 エラーの解決策 May 08, 2024 pm 03:50 PM

1. [スタート]メニューを起動し、[cmd]と入力し、[コマンドプロンプト]を右クリックし、[管理者として実行]を選択します。 2. 次のコマンドを順番に入力します (注意してコピーして貼り付けてください): SCconfigwuauservstart=auto、Enter キーを押す SCconfigbitsstart=auto、Enter キーを押す SCconfigcryptsvcstart=auto、Enter キーを押す SCconfigtrustedinstallerstart=auto、Enter キーを押す SCconfigwuauservtype=share、Enter キーを押す netstopwuauserv 、enter netstopcryptS を押す

Golang API のキャッシュ戦略と最適化 Golang API のキャッシュ戦略と最適化 May 07, 2024 pm 02:12 PM

GolangAPI のキャッシュ戦略により、パフォーマンスが向上し、サーバーの負荷が軽減されます。一般的に使用される戦略は、LRU、LFU、FIFO、TTL です。最適化手法には、適切なキャッシュ ストレージの選択、階層型キャッシュ、無効化管理、監視とチューニングが含まれます。実際には、データベースからユーザー情報を取得する API を最適化するために LRU キャッシュが使用されます。それ以外の場合は、データベースからデータを取得した後にキャッシュを更新できます。

PHP 開発におけるキャッシュ メカニズムとアプリケーションの実践 PHP 開発におけるキャッシュ メカニズムとアプリケーションの実践 May 09, 2024 pm 01:30 PM

PHP 開発では、キャッシュ メカニズムにより、頻繁にアクセスされるデータがメモリまたはディスクに一時的に保存され、データベース アクセスの数が削減され、パフォーマンスが向上します。キャッシュの種類には主にメモリ、ファイル、データベース キャッシュが含まれます。キャッシュは、組み込み関数またはサードパーティのライブラリ (cache_get() や Memcache など) を使用して PHP に実装できます。一般的な実用的なアプリケーションには、データベース クエリ結果をキャッシュしてクエリ パフォーマンスを最適化したり、ページ出力をキャッシュしてレンダリングを高速化したりすることが含まれます。キャッシュ メカニズムにより、Web サイトの応答速度が効果的に向上し、ユーザー エクスペリエンスが向上し、サーバーの負荷が軽減されます。

Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法_Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法 Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法_Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法 May 08, 2024 pm 05:10 PM

まず、システム言語を簡体字中国語表示に設定して再起動する必要があります。もちろん、以前に表示言語を簡体字中国語に変更したことがある場合は、この手順をスキップできます。次に、レジストリ regedit.exe の操作を開始し、左側のナビゲーション バーまたは上部のアドレス バーで HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlNlsLanguage に直接移動し、InstallLanguage キーの値と Default キーの値を 0804 に変更します (英語に変更する場合)。まずシステムの表示言語を en-us に設定し、システムを再起動してから、すべてを 0409 に変更します) この時点でシステムを再起動する必要があります。

PHP 配列のページネーションで Redis キャッシュを使用するにはどうすればよいですか? PHP 配列のページネーションで Redis キャッシュを使用するにはどうすればよいですか? May 01, 2024 am 10:48 AM

Redis キャッシュを使用すると、PHP 配列ページングのパフォーマンスを大幅に最適化できます。これは、次の手順で実現できます。 Redis クライアントをインストールします。 Redisサーバーに接続します。キャッシュ データを作成し、データの各ページをキー「page:{page_number}」を持つ Redis ハッシュに保存します。キャッシュからデータを取得し、大規模な配列での高コストの操作を回避します。

Win11でダウンロードしたアップデートファイルの探し方_Win11でダウンロードしたアップデートファイルの場所を共有する Win11でダウンロードしたアップデートファイルの探し方_Win11でダウンロードしたアップデートファイルの場所を共有する May 08, 2024 am 10:34 AM

1. まず、デスクトップ上の[このPC]アイコンをダブルクリックして開きます。 2. 次に、マウスの左ボタンをダブルクリックして [C ドライブ] に入ります。システム ファイルは通常、自動的に C ドライブに保存されます。 3. 次に、C ドライブで [windows] フォルダーを見つけ、ダブルクリックしてに入ります。 4. [windows]フォルダーに入ったら、[SoftwareDistribution]フォルダーを見つけます。 5. 入力後、win11 のダウンロード ファイルとアップデート ファイルがすべて含まれている [ダウンロード] フォルダーを見つけます。 6. これらのファイルを削除したい場合は、このフォルダー内で直接削除してください。

PHP Redis キャッシュ アプリケーションとベスト プラクティス PHP Redis キャッシュ アプリケーションとベスト プラクティス May 04, 2024 am 08:33 AM

Redis は、高性能のキー/値キャッシュです。 PHPRedis 拡張機能は、Redis サーバーと対話するための API を提供します。 Redis に接続し、データを保存および取得するには、次の手順を使用します。 接続: Redis クラスを使用してサーバーに接続します。ストレージ: set メソッドを使用してキーと値のペアを設定します。取得: get メソッドを使用してキーの値を取得します。

Docker環境にPECLを使用して拡張機能をインストールするときにエラーが発生するのはなぜですか?それを解決する方法は? Docker環境にPECLを使用して拡張機能をインストールするときにエラーが発生するのはなぜですか?それを解決する方法は? Apr 01, 2025 pm 03:06 PM

エラーの原因とソリューションPECLを使用してDocker環境に拡張機能をインストールする場合、Docker環境を使用するときに、いくつかの頭痛に遭遇します...

See all articles