Redis がさまざまなメモリ アロケータを使用して断片化率を比較する方法
Redis の zmalloc.c のソース コードでは、次のコードを確認できます:
/* tcmalloc を使用するときに、malloc/free などを明示的にオーバーライドします。 */
#if 定義されています。 (USE_TCMALLOC )
#define malloc(size) tc_malloc(size)
tc_calloc(count,size) は calloc 関数の定義です
#define realloc(ptr,size) ) tc_realloc( ptr,size)
#define free(ptr) tc_free(ptr)
#elif defined(USE_JEMALLOC)
#define malloc(size) je_malloc(size) )
次の文はリクエストに応じて書き直されました。 ステートメント「#define calloc(count,size) je_calloc(count,size)」は、標準定義関数「calloc」を「je_calloc」という名前のカスタム関数に置き換えるために使用されます。 size) je_realloc(ptr,size)
#define free(ptr) je_free(ptr)
#endif
上記のコードから、Redis がコンパイル時にtcmalloc を使用する場合は、標準 libc の関数実装が tcmalloc に対応する関数に置き換えられます。この後、jemalloc が有効かどうかを確認しますが、有効でない場合は標準 libc のメモリ管理機能が使用されます。
最新バージョン 2.4.4 では、jemalloc がソース コード パッケージの一部として含まれており、直接使用できるようになりました。 tcmalloc を使用したい場合は、自分でインストールする必要があります。
tcmalloc パッケージのインストール方法について簡単に説明します。tcmalloc は google-proftools の一部であるため、実際には google-proftools をインストールする必要があります。 64 ビット マシンにインストールする場合は、必要な libunwind ライブラリを最初にインストールする必要があります。
wget http://download.savannah.gnu.org/releases/libunwind/libunwind-0.99-alpha.tar.gz
tar zxvf libunwind-0.99-alpha.tar.gz
cd libunwind-0.99-alpha/
CFLAGS=-fPIC ./configure
make CFLAGS=-fPIC
make CFLAGS=-fPIC install
Redis がさまざまなメモリ アロケーターを使用する方法の断片化率の比較
# 次に、google-preftools をインストールします。 wget http://google-perftools.googlecode.com/files/ google- perftools-1.8.1.tar.gz tar zxvf google-perftools-1.8.1.tar.gz cd google-perftools-1.8.1/ 。 /configure --disable-cpu-profiler --disable-heap-profiler --disable-heap-checker --disable-debugalloc --enable-minimal make && make install Sudo echo "/usr/local/lib" > /etc/ld.so.conf.d/usr_local_lib.conf #このファイルがない場合は、自分で作成してください sudo /sbin/ldconfig次に Redis をインストールし、tcmalloc を有効にするときに対応するパラメータを指定します。
## $curl -O http://redis.googlecode.com/files/redis-2.4.4.tar. gz
$ tar xzvf redis-2.4.4.tar.gz
# $ cd redis-2.4.4# $ make USE_TCMALLOC=yes FORCE_LIBC_MALLOC=yes
# $ sudo make install Redisを再起動すると、infoコマンドで使用されているメモリアロケータが確認できます。 この記事の主題に戻り、この記事では、tcmalloc、jemalloc、libc に対応する 3 つのメモリ アロケータについて説明します。以下は、Redis 情報情報から取得した、パフォーマンスと断片化率を評価するために設計された簡単なテスト結果です。テストでは異なるアロケーターが使用されました。以下に示すように、tcmalloc を使用すると断片化率が最も低くなり、jemalloc は 1.02、libc のアロケータ断片化率は 1.31 であることがわかります。 :675.57M used_memory_rss:715169792 used_memory_peak:708814040 used_memory_peak_human:675.98M mem_fragmentation_ratio:1.01 mem_ allocator:tcmalloc -1.7 used_memory:708381168 used_menory_human:675.56M used_memory_rss:723587072 used_memory_peak:708803768# used_memory_peak_human:675.97 M
mem_fragmentation_ratio:1.02
mem_allocator:jemalloc-2.2.1
used_memory:869000400
used_menory_human:828.74M
used_memory_rss:1136689152
used_memory_peak:868992208
used_memory_peak_human:828.74M
mem_fragmentation_ratio:1.31
mem_allocator:libc
以上がRedis がさまざまなメモリ アロケータを使用して断片化率を比較する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

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

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

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

Redisは、並行性が高く、遅延の低いシナリオの従来のデータベースよりも優れていますが、複雑なクエリやトランザクション処理には適していません。 1.Redisは、メモリストレージ、高速読み取り速度、および高い並行性と低遅延の要件に適しています。 2.従来のデータベースは、ディスクに基づいており、複雑なクエリとトランザクション処理をサポートし、データの一貫性と永続性が強い。 3. Redisは、従来のデータベースのサプリメントまたは代替品として適していますが、特定のビジネスニーズに応じて選択する必要があります。

Linuxシステムは、リソースの過度の使用を防ぐために、ULIMITコマンドを介してユーザーリソースを制限します。 1.ulimitは、ファイル記述子(-n)、メモリサイズ(-v)、スレッドカウント(-u)などの数を制限できるビルトインシェルコマンドであり、ソフト制限(現在の有効値)とハードリミット(最大上限)に分割されます。 2。Ulimit-N2048などの一時的な変更には、Ulimitコマンドを直接使用しますが、現在のセッションでのみ有効です。 3.永続的な効果を得るには、/etc/security/limits.confを変更し、PAM構成ファイルを変更し、SessionRequiredPam_limits.soを追加する必要があります。 4. SystemDサービスは、ユニットファイルにLIMを設定する必要があります

Redisは主にデータベースですが、単なるデータベース以上のものです。 1.データベースとして、Redisは持続性をサポートし、高性能のニーズに適しています。 2。キャッシュとして、Redisはアプリケーションの応答速度を改善します。 3。メッセージブローカーとして、Redisはリアルタイム通信に適したPublish-Subscribeモードをサポートしています。

PHPStudyを使用して動的なPHP Webサイトを構築する手順には次のものがあります。1。PHPSTUDYをインストールし、サービスを開始します。 2。ウェブサイトのルートディレクトリとデータベース接続を構成します。 3.動的コンテンツを生成するPHPスクリプトを書き込みます。 4.ウェブサイトのパフォーマンスをデバッグして最適化します。これらの手順を通じて、完全に機能的な動的PHP Webサイトをゼロから構築できます。

Redisは、高性能と柔軟性のためにSQLデータベースを超えています。 1)Redisは、メモリストレージを介して非常に速い読み取りおよび書き込み速度を実現します。 2)複雑なデータ処理に適したリストやコレクションなど、さまざまなデータ構造をサポートしています。 3)シングルスレッドモデルは開発を簡素化しますが、高い並行性はボトルネックになる可能性があります。

Redisisanopen-Source、In-MemoryDatastructurestoreStoreSadatabase、Cache、AndmessageBroker、ExcellingInspeedandversatility.ItisisWidely-susederCaching、Real-Timeanalytics、Session Management、AndleaderboardsdueTotutsuptorututrututrututruturturturturturturesturesaddataacys

Laravelのページキャッシュ戦略は、Webサイトのパフォーマンスを大幅に改善できます。 1)キャッシュヘルパー関数を使用して、キャッシュなどのページキャッシュを実装します::メソッドを記憶します。 2)Redisなどの適切なキャッシュバックエンドを選択します。 3)データの一貫性の問題に注意を払うと、細かいキャッシュまたはイベントリスナーを使用してキャッシュをクリアできます。 4)さらに最適化は、ルーティングキャッシュ、キャッシュ、キャッシュタグを表示します。これらの戦略を合理的に適用することにより、ウェブサイトのパフォーマンスを効果的に改善できます。

Laravelでは、RedisとMemcachedを使用してキャッシュポリシーを最適化できます。 1)RedisまたはMemcachedを構成するには、.ENVファイルに接続パラメーターを設定する必要があります。 2)Redisは、データ損失のリスクが高い複雑なシナリオやシナリオに適したさまざまなデータ構造と持続性をサポートしています。 Memcachedは、簡単なデータへの迅速なアクセスに適しています。 3)CacheFacadeを使用して統一されたキャッシュ操作を実行すると、基礎となるレイヤーが構成されたキャッシュバックエンドを自動的に選択します。
