ホームページ データベース Redis Redis のメモリ割り当てと使用量統計の手法は何ですか?

Redis のメモリ割り当てと使用量統計の手法は何ですか?

May 27, 2023 pm 07:44 PM
redis

具体的には:

Google の TC_MALLOC ライブラリがシステムに存在する場合は、元の malloc 関数ファミリーの代わりに tc_malloc 関数ファミリーを使用します。

現在のシステムが Mac システムの場合は、メモリ割り当て機能を使用します。

他の場合には、割り当てられたスペースのサイズを記録するために、割り当てられた各スペースの先頭に追加の固定長フィールドが割り当てられます。

ソース コードはそれぞれ config.h と zmalloc.c にあります。

/* config.h */

#if Definition(USE_TCMALLOC)

#include

#if TC_VERSION_MAJOR >= 1 && TC_VERSION_MINOR >= 6

#define HAVE_MALLOC_SIZE 1

#define redis_malloc_size(p) tc_malloc_size(p)

#endif

#elif 定義(__APPLE__)

#include

#define HAVE_MALLOC_SIZE 1

#define redis_malloc_size(p) malloc_size( p )

#endif

/* zmalloc.c */

#ifdef HAVE_MALLOC_SIZE

#define PREFIX_SIZE (0)

# else

#if 定義されている場合(__sun)

#define PREFIX_SIZE (sizeof(long long))

#else

#define PREFIX_SIZE (sizeof( size_t ))

#endif

#endif

Mac プラットフォームの tc_malloc と malloc 関数ファミリーは、割り当てられた領域のサイズを計算する関数を提供するため (それぞれ tc_malloc_size と malloc_size) ) なので、サイズを記録するために別のスペースを割り当てる必要はありません。 Linux および Sun プラットフォームの場合、割り当てられた領域のサイズを記録する必要があります。 Linux の場合は、sizeof(size_t) 固定長フィールド レコードを使用し、Sun OS の場合は、sizeof(long long) 固定長フィールド レコードを使用します。それが、上記のソース コードの PREFIX_SIZE マクロです。

この文をもう一度表現してください: このレコードの目的は、現在のプロセスによって占有されているメモリの量を計算することです。 zmalloc.c には、次のような静的変数があります。

static size_t used_memory = 0;

これは、プロセスが現在占有しているメモリの総量を記録します。メモリが割り当てられるか解放されるたびに、この変数を更新する必要があります。メモリを割り当てるときに、割り当てるメモリの量を明確に知ることができるためです。ただし、メモリを解放する場合 (malloc_size 関数を提供しないプラットフォームの場合)、解放するメモリへのポインタを指定するだけでは、どれだけのスペースが解放されるのかを知ることはできません。この場合、PREFIX_SIZEで指定された固定長フィールドが機能し、そこに記録されている情報から空間のサイズを取得することができる。 zmalloc 関数は次のとおりです (無関係なコードを削除します):

void *zmalloc(size_t size) {

void *ptr = malloc(size PREFIX_SIZE);

if ( !ptr) zmalloc_oom(size);

*((size_t*)ptr) = size;

update_zmalloc_stat_alloc(size PREFIX_SIZE,size);

return (char*) ptr PREFIX_SIZE;

。 Mac システムで実行している場合、または tc_malloc を使用している場合、PREFIX_SIZE の値はゼロです。次に、ポインタ ptr が指すメモリ ブロックの最初の size_t バイトを使用して、メモリ ブロックに割り当てられたサイズを記録します。最後に返されるのは、レコード領域を超えたポインターです。 zfree 関数も同様です (無関係なコードを削除しています):

void zfree(void *ptr) {

void *realptr;

size_t oldsize;

if ( ptr == NULL) return;

realptr = (char*)ptr-PREFIX_SIZE;

oldsize = *((size_t*)realptr);

update_zmalloc_stat_free( oldsize PREFIX_SIZE );

free(realptr);

#endif

}

まずポインタを PREFIX_SIZE だけ前方に移動し、次に保存されたスペースを取り出します。スペースの長さを割り当てるとき。最後に、スペース全体を解放します。

2 つのマクロ update_zmalloc_stat_alloc(__n,__size) と update_zmalloc_stat_free(__n) は、メモリの割り当てまたは解放時に used_memory 変数を更新する役割を果たします。これをマクロとして定義するのは、主に効率を考慮したためです。次のように、これを関数に復元します。

void update_zmalloc_stat_alloc(__n,__size)

{

do {

size_t _n = (__n );

size_t _stat_slot = (__size < ZMALLOC_MAX_ALLOC_STAT) ? __size : ZMALLOC_MAX_ALLOC_STAT; if (_n&(sizeof(long)-1)) _n = sizeof(long)-(_n&(sizeof(long)-1)); if (zmalloc_thread_safe) { pthread_mutex_lock(&used_memory_mutex); 使用済みメモリ = _n; zmalloc_allocations[_stat_slot]; pthread_mutex_unlock(&used_memory_mutex); } それ以外 { 使用済みメモリ = _n; zmalloc_allocations[_stat_slot]; } しながら(0) } void update_zmalloc_stat_free(__n) { する { サイズ_t _n = (__n); if (_n&(sizeof(long)-1)) _n = sizeof(long)-(_n&(sizeof(long)-1)); if (zmalloc_thread_safe) { pthread_mutex_lock(&used_memory_mutex); 使用済みメモリ -= _n; pthread_mutex_unlock(&used_memory_mutex); } それ以外 { 使用済みメモリ -= _n; } しながら(0) } コード内の used_memory 変数を更新することに加えて、他にも注意すべき点がいくつかあります。 まず、_n の下位ビットが切り上げられ、最終的に _n は sizeof(long) の倍数になります。たとえば、32 ビット システムの場合、sizeof(long) == 100 (バイナリ)になります。アップすると、下位 2 ビットは 0 になります。 プロセス内に複数のスレッドがある場合、変数を更新するときにロックをロックする必要があります。 zmalloc 関数で更新される別の統計: zmalloc_allocations[] があります。 zmalloc.c では、zmalloc_allocations は次のように定義されます。 size_t zmalloc_allocations[ZMALLOC_MAX_ALLOC_STAT 1]; その機能は、プログラムがメモリを割り当てるときに、さまざまなサイズのスペースに対するリクエストの数をカウントすることです。統計領域の範囲は 1 バイトから 256 バイトであり、256 バイトを超える領域は 256 としてカウントされます。統計結果は、zmalloc_allocations_for_size 関数を呼び出すことによって返されます。 size_t zmalloc_allocations_for_size(size_t サイズ) { if (size > ZMALLOC_MAX_ALLOC_STAT) return 0;

Return zmalloc_allocations[size];

}

zmalloc_used_memory 関数を呼び出すと、別のメモリ使用量統計が返されます。

Size_t zmalloc_used_memory(void) {

size_t um;

if (zmalloc_thread_safe) pthread_mutex_lock(&used_memory_mutex);

um = used_memory;

if (zmalloc_thread_safe) pthread_mutex_unlock(&used_memory_mutex);

return um;

}

さらに、zmalloc.c は、さまざまなシステム用の zmalloc_get_rss 関数も実装します。 、メモリ使用量のシステム統計は、/proc/$pid/stat ファイルを読み取ることで取得されます。

以上が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