RedisDb
Redis サーバーにはデフォルトで 16 のデータベースがあり、1 つのデータベースが 1 つの RedisDB データ構造に対応します。
typedef struct redisDb { dict *dict; dict *expires; dict * blocking_keys; dict * ready_keys; dict * watched_keys; ...... }
dict: キー空間ハッシュ テーブル。すべてのキーと値のペアの保存に使用されます。
expires: 有効期限ハッシュ テーブル。保存に使用されます。キーの有効期限 Time
blocking_keys: ブロックされた状態のキーと対応するクライアント
ready_keys: ブロックされていない状態のキーと対応するクライアント、およびblocking_keys属性は相対的です。
watched_keys: 監視キーと対応するクライアント。主にトランザクションに使用されます。
RedisObject
Redis キー値はすべて redisObject オブジェクトです。Redis データベースに新しいキーと値のペアを作成するたびに、キー名の redisObject オブジェクトとキー値の redisObject オブジェクトが生成されます
trpedef struct RedisObject { int4 type; int4 encoding; void *ptr; int24 lru; int32 refcount; }
Field | Description | Description |
---|---|---|
type | は、Redis に対応する型を表すために使用されます。 | 文字列、リスト、ハッシュ、セット、zset、ストリームなどは列挙型で表現されます |
encoding | 内部エンコーディング | int 、embstr、raw、hashtable、quicklist、ziplist、intset、skiplist など。列挙型 |
lru | 24 ビットで表され、オプションの LFU または LRU | LRUの場合は最終アクセス時刻を表し、LFUの場合は上位16ビットでアクセス時刻を分単位で、下位8ビットでアクセス頻度を表します. 頻度の増加は確率アルゴリズムを使用しており、数値が大きいほど増加しにくくなり、アクセス時間が更新されると一定の確率でアクセス頻度が減衰します。 (両方に共通) アクセス時間は数値の剰余であり、現在時刻も剰余です。現在時間がアクセス時間より大きい場合は 2 つの数値の差になります。現在時刻がアクセス時間より小さい場合は、2 つの数値の差になります。アクセス時間は、現在時間にモジュラスとアクセス時間を加えたものです。差分 |
refcount | 参照カウント | 初期値は1です。これは、実際のアプリケーションではあまり重要ではありません。 |
ptr | Pointer は 8 バイトを占め、data | dict のアドレスを指します。有効期限が切れた場合など、ポインタは同じアドレスを指します。 |
object
コマンドは、RedisObject に対する関連操作です。
メモリ削除戦略を変更する
object idletime key # キーのアイドル時間、つまりキーが最後に読み書きされてからのおおよその時間を返します。 lfu モードでは使用できません
config set maxmemory-policy volatile-lfu # 修改内存淘汰策略 set name zhangsan object freq name # 获取计数值,仅lfu模式下可用,初始化为5 get name object freq name # 再次访问,返回为6
int
文字列値が整数で、long の最大値以下の場合、エンコードは int 型となり、ptr は直接ポイントしますint 型アドレス
embstr と raw
Redis への文字列は SDS (Simple Dynamic String、単純な文字列) と呼ばれ、キー、非整数文字列値
trpedef struct SDS { int8 capacity; // 数组容量 int8 len; // 实际长度 int8 flags; byte[] content; // 数组内容 }# に対応します。
##SDS は Java の ArrayList 構造 に似ていることがわかりますが、初期長を割り当て、長さを超えた場合に拡張します。 Redis では、文字列の長さが 512M を超えてはいけないと規定されています。
長さが特に短い場合は embstr 形式で格納し、長さが 44 バイトを超える場合は raw 形式で格納します。 メモリ アロケータの最大割り当て単位は 64 バイト、RedisObject は 16 バイト、SDS 識別子は 3 バイト、NULL で終わる文字列は 1 バイト必要であることがわかっています。 44 以下の場合、メモリを割り当てる必要があるのは 1 回だけです。 RedisObject と SDS は同じメモリ ユニット内にあり、このデータ構造を embstr と呼びますが、同じメモリ ユニット内にないデータ構造は raw と呼ばれます。 dictdict (エンコーディングはハッシュテーブル型、ディクショナリ) は、hash、set、zset (値とスコアの間のマッピングを保存するために使用) コレクションに対応します。dict は Java の HashMap 構造 に似ています。違いは、HashMap の展開には配列が必要であり、それを走査し、古いデータを再ハッシュして配列の下にハングすることです。 -threaded Redisでは、このような時間のかかる処理に耐えるために、2つの配列を使用し、最初に戻り、空いたときにデータを少しずつ移動し、移動が完了すると古いデータがクリアされます。このプロセスを プログレッシブ リハッシュ と呼びます。 rree
以上がRedis データ構造の原理は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Redisは、データをキャッシュし、分散ロックとデータの持続性を実装することにより、アプリケーションのパフォーマンスとスケーラビリティを向上させます。 1)キャッシュデータ:Redisを使用して頻繁にアクセスしたデータをキャッシュして、データアクセス速度を向上させます。 2)分散ロック:Redisを使用して分散ロックを実装して、分散環境での操作のセキュリティを確保します。 3)データの持続性:データの損失を防ぐために、RDBおよびAOFメカニズムを介してデータセキュリティを確保します。

Redisのデータモデルと構造には、5つの主要なタイプが含まれます。1。文字列:テキストまたはバイナリデータの保存に使用され、原子操作をサポートします。 2。リスト:キューとスタックに適した注文された要素コレクション。 3.セット:順序付けられていない一意の要素セット、セット操作をサポートします。 4。注文セット(sortedset):ランキングに適したスコアを持つ一意の要素セット。 5。ハッシュテーブル(ハッシュ):オブジェクトの保存に適したキー価値ペアのコレクション。

Redisのデータベースメソッドには、メモリ内データベースとキー価値ストレージが含まれます。 1)Redisはデータをメモリに保存し、速く読み取り、書き込みます。 2)キー価値のペアを使用してデータを保存し、キャッシュやNOSQLデータベースに適したリスト、コレクション、ハッシュテーブル、注文コレクションなどの複雑なデータ構造をサポートします。

Redisは、高速パフォーマンス、リッチデータ構造、高可用性とスケーラビリティ、持続性能力、幅広いエコシステムサポートを提供するため、強力なデータベースソリューションです。 1)非常に速いパフォーマンス:Redisのデータはメモリに保存され、非常に速い読み取り速度と書き込み速度が高く、高い並行性と低レイテンシアプリケーションに適しています。 2)豊富なデータ構造:さまざまなシナリオに適したリスト、コレクションなど、複数のデータ型をサポートします。 3)高可用性とスケーラビリティ:マスタースレーブの複製とクラスターモードをサポートして、高可用性と水平スケーラビリティを実現します。 4)持続性とデータセキュリティ:データの整合性と信頼性を確保するために、データの持続性がRDBとAOFを通じて達成されます。 5)幅広い生態系とコミュニティのサポート:巨大なエコシステムとアクティブなコミュニティにより、

Redisの主な機能には、速度、柔軟性、豊富なデータ構造のサポートが含まれます。 1)速度:Redisはメモリ内データベースであり、読み取り操作はほとんど瞬間的で、キャッシュとセッション管理に適しています。 2)柔軟性:複雑なデータ処理に適した文字列、リスト、コレクションなど、複数のデータ構造をサポートします。 3)データ構造のサポート:さまざまなビジネスニーズに適した文字列、リスト、コレクション、ハッシュテーブルなどを提供します。

Redisのコア関数は、高性能のメモリ内データストレージおよび処理システムです。 1)高速データアクセス:Redisはデータをメモリに保存し、マイクロ秒レベルの読み取り速度と書き込み速度を提供します。 2)豊富なデータ構造:文字列、リスト、コレクションなどをサポートし、さまざまなアプリケーションシナリオに適応します。 3)永続性:RDBとAOFを介してディスクにデータを持続します。 4)サブスクリプションを公開:メッセージキューまたはリアルタイム通信システムで使用できます。

Redisは、次のようなさまざまなデータ構造をサポートしています。1。文字列、単一価値データの保存に適しています。 2。キューやスタックに適したリスト。 3.非重複データの保存に使用されるセット。 4。ランキングリストと優先キューに適した注文セット。 5。オブジェクトまたは構造化されたデータの保存に適したハッシュテーブル。

Redisカウンターは、Redisキー価値ペアストレージを使用して、カウンターキーの作成、カウントの増加、カウントの減少、カウントのリセット、およびカウントの取得など、カウント操作を実装するメカニズムです。 Redisカウンターの利点には、高速速度、高い並行性、耐久性、シンプルさと使いやすさが含まれます。ユーザーアクセスカウント、リアルタイムメトリック追跡、ゲームのスコアとランキング、注文処理などのシナリオで使用できます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

WebStorm Mac版
便利なJavaScript開発ツール

メモ帳++7.3.1
使いやすく無料のコードエディター

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

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

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター
