目次
1. 概要
2. カーディナリティとは何ですか?
3. コマンド
3.1 PFADD
3.2 PFCOUNT
3.3 PFMERGE
ホームページ データベース Redis HyperLogLog を使用して Redis を実装する方法

HyperLogLog を使用して Redis を実装する方法

May 26, 2023 pm 05:41 PM
redis hyperloglog

1. 概要

Redis は、カーディナリティ統計のためにバージョン 2.8.9 で HyperLogLog データ構造を追加しました。利点は、入力要素の数が非常に多い場合、カーディナリティの計算に必要なスペースが比較的少なくて済むことです。小さく、一般に比較的一定です。

Redis では、ほぼ 2^64 の異なる要素のカーディナリティを計算するために、各 HyperLogLog キーに必要なメモリは 12 KB だけです。これは、要素が多いコレクションほど多くのメモリを消費するカーディナリティの計算とは対照的です。ただし、HyperLogLog は入力要素に基づいてカーディナリティを計算するだけで、入力要素自体は保存しないため、コレクションのように入力の個々の要素を返すことはできません。

2. カーディナリティとは何ですか?

たとえば、データ セットが {1, 3, 5, 7, 5, 7, 8} の場合、このデータのカーディナリティ セットはセットは {1, 3, 5 ,7, 8}、カーディナリティ (非繰り返し要素) は 5 です。カーディナリティの推定とは、許容誤差範囲内でカーディナリティを迅速に計算することです。

3. コマンド

現在、HyperLogLog でサポートされているコマンドは PFADD、PFCOUNT、および PFMERGE の 3 つだけです。まずは一つずつ紹介していきましょう。

3.1 PFADD

利用可能な最も古いバージョン: 2.8.9。時間計算量: O(1)。

PFADD コマンドは、要素 (複数の要素を指定可能) を HyperLogLog データ構造に追加し、最初のパラメーター キーで指定されたキーに格納できます。カーディナリティ推定 (評価された要素の数) が変化した場合は 1 を返し、それ以外の場合は 0 を返します。つまり、コマンドの実行後にカーディナリティ推定が変化したかどうかを確認します。指定されたキーが存在しない場合は、空の HyperLogLog データ構造 (つまり、指定された文字列長とエンコーディングを持つ Redis 文字列) が作成されます。要素パラメータを指定せずにキーのみを指定してコマンドを呼び出すこともできます。キーが存在する場合は何もせず 0 を返し、キーが存在しない場合は新しい HyperLogLog データ ノードが作成されて 1 を返します。基本的に、要素を保存せずに新しい HyperLogLog データ構造を生成するだけです。

(1) 構文形式:

PFADD key element [element ...]
ログイン後にコピー

(2) 戻り値:

整数型、要素が 1 つ以上追加された場合は 1 が返され、それ以外の場合は 0 が返されます。 。

(3) 例:

127.0.0.1:6379> PFADD hll a b c d e f g
(integer) 1
127.0.0.1:6379> pfcount hll
(integer) 7
ログイン後にコピー

3.2 PFCOUNT

利用可能な最も古いバージョン: 2.8.9。時間計算量: O(1)。複数の比較的大きなキーの場合、時間計算量は O(N) です。

PFCOUNT コマンドを使用して、HyperLogLog の推定カーディナリティ値 (つまり、要素の数) を取得します。このコマンドは、キーが存在しない場合は 0 を返し、それ以外の場合はキーのカーディナリティの推定値を返します。複数のキーの場合、複数の HyperLogLog を一時的な HyperLogLog にマージすることで計算された、複数の HyperLogLog の和集合のカーディナリティ推定値が返されます。 HyperLogLog は、最小限の一定量のメモリを使用して、コレクションの一意の要素の数をカウントできます。各 HyperLogLog は、12K とキー自体の数バイトのみを使用します。

(1) 構文形式:

PFCOUNT key [key ...]
ログイン後にコピー

(2) 戻り値:

Integer、指定された HyperLogLog のカーディナリティ推定値を返します。複数の HyperLogLog がある場合、和集合はカーディナリティの推定値。

(3) 例:

127.0.0.1:6379> PFADD hll foo bar zap
(integer) 1
127.0.0.1:6379> PFADD hll zap zap zap
(integer) 0
127.0.0.1:6379> PFADD hll foo bar
(integer) 0
127.0.0.1:6379> PFCOUNT hll
(integer) 3
127.0.0.1:6379> PFADD some-other-hll 1 2 3
(integer) 1
127.0.0.1:6379> PFCOUNT some-other-hll
(integer) 3
127.0.0.1:6379> PFCOUNT hll some-other-hll
(integer) 6
ログイン後にコピー

(4) 制限事項:

HyperLogLog によって返される結果は正確ではなく、エラー率は約 0.81% です。

このコマンドを使用すると、HyperLogLog が変更され、最後に計算されたベースを保存するために 8 バイトが使用されます。したがって、技術的に言えば、PFCOUNT は書き込みコマンドです。

(5) パフォーマンスの問題

集中的な HyperLogLog の処理には理論的には時間がかかりますが、キーが 1 つだけ指定されている場合でも PFCOUNT コマンドは高いパフォーマンスを発揮します。これは、PFCOUNT が最後の計算の基数をキャッシュし、ほとんどの場合 PFADD コマンドがレジスタを更新しないため、この基数が常に変更されるわけではないためです。したがって、1 秒あたり数百のリクエストの効果を達成できます。

PFCOUNT コマンドを使用して複数のキーを処理すると、HyperLogLog がマージされます。この手順は非常に時間がかかります。さらに重要なのは、共用体の計算されたカーディナリティをキャッシュできないことです。複数のキーを使用する場合、PFCOUNT の実行には時間がかかることがあります (通常はミリ秒程度)。そのため、過度に使用することはお勧めできません。

このコマンドの単一キー実行セマンティクスと複数キー実行セマンティクスは異なり、パフォーマンスも異なることに注意してください。マルチキー実行セマンティクスを過度に使用することはお勧めできません。

3.3 PFMERGE

利用可能な最も古いバージョン: 2.8.9。時間計算量: O(N)、N はマージされる HyperLogLog の数です。

PFMERGE コマンドを使用して、複数の HyperLogLog を 1 つの HyperLogLog にマージできます。マージされた HyperLogLog のカーディナリティの推定値は、指定されたすべての HyperLogLog の結合を取得することによって計算されます。計算結果は指定したキーに保存されます。

構文形式:

PFMERGE destkey sourcekey [sourcekey ...]
ログイン後にコピー

戻り値:

OK を返します。

例:

127.0.0.1:6379> PFADD hll1 foo bar zap a
(integer) 1
127.0.0.1:6379> PFADD hll2 a b c foo
(integer) 1
127.0.0.1:6379> PFMERGE hll3 hll1 hll2
OK
127.0.0.1:6379> PFCOUNT hll3
(integer) 6
ログイン後にコピー

以上がHyperLogLog を使用して 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