検索
ホームページデータベースRedisRedis で永続性を実現する方法

Redis で永続性を実現する方法

#Redis は現在の Web プログラミングに欠かせないサービスですが、その特徴は明らかで、memcached と比較してデータを失わずにキャッシュして再起動できるため、非常に使いやすいです。そこで問題は、それがどのように行われるのかということです。

RDB

RDB は永続化の手段であり、特定の条件下でメモリ内のデータをディスクに書き込みます。では、どのような条件で書かれているのでしょうか?何も考えずに書くことは不可能です。1つずつ書くとパフォーマンスに影響します。1つ書くまでに長い時間待つことはできません。途中でダウンタイムが発生してすべてのデータが失われる場合は、使用した方が良いです。 memcached。 Redis 構成には次のような構成があります:

save 900 1

save 300 10

save 60 10000

非常に重要な構成部分であり、これは RDB 永続性の中核です。意味:

1. 900 秒以内に 1 つのキーが変更 (挿入または更新) された場合、それをディスクに同期します

2. 300 秒以内に、If 10 がありますキーの変更 (挿入または更新) がある場合は、ディスクに同期します

#3。60 秒間に 10,000 回のキーの変更 (挿入または更新) がある場合、ディスクに同期します

これらの時点と変更の数はどうやって知るのですか? 現時点では他に非常に重要なものが 2 つあり、1 つはダーティ カウンターと呼ばれ、もう 1 つは lastsave (最後の保存の時刻) と呼ばれます。具体的には、最後に保存してからの時間を記録します。キーの数を変更します。Lastsave は、保存が実行された時間を記録します。たとえば、初期時間は time1 で、ダーティは 0 です。この時点では、20 個のキーが変更されており、ダーティは 20 です、現在時刻が time2、time2-time1 >= 300 の場合、2 番目の条件が満たされると、メモリ内のデータが保存され、dirty が 0 にクリアされ、条件がトリガーされるのを待ちます。

60 秒以内に 100,000 個のキーがある場合、問題が発生します。大量のディスク IO が発生すると、redis のメイン プロセスがブロックされ、その間のすべてのコマンドが実行されなくなります。これはできるでしょうか? そこで、bgsave と呼ばれるプロセスが登場しました。これは、メインの Redis プロセスからフォークされたサブプロセスであり、RDB 永続化作業の実行に特化しています。

保存されたファイル形式はバイナリ形式です。データベースがダウンした場合でも、人間による回復は必要なく、redis が自動的にディスク ファイルを読み取ります。

AOF

AOF は RDB とは異なり、実行したコマンドを保存します。aof 機能をオンにすると、実行された更新コマンドは aof に直接書き込まれません。ファイル。最初に aof buf に書き込む代わりに、常に buf に書き込むことができるわけではないことがわかっています。buf はメモリでもあるため、いつディスクに同期できるでしょうか? redis にもそのような構成があります。

appendfsync always

appendfsync Everysec

appendfsync no

意味:

1.更新があるので、コマンド

2 を同期します。最後の同期時刻が今から 1 秒以上後である場合は、

3 を同期します。同期されていない場合は、動作を待ちます。システム自体が判断します (暇なときに同期します))

分析中、最初のタイプの IO は頻繁であり、IO プレッシャーが高いですが、データが失われる可能性は最も小さいです。 3 番目のタイプの IO は、プレッシャーがほとんどなく、データが失われる可能性が高すぎるタイプです。すべてを考慮すると、一般的には 2 番目のオプションです。しかし、まだ疑問があります。INCR num を 100 回実行しました。論理的には、num は 100 です。aof には同じコマンドが 100 個あります。何も問題はありません。では、INCR num を 100 回実行するのと SET num 100 回を実行するのとの違いは何ですか? ? 結果は同じですが、前者は99倍のスペースを必要とし、非常に無駄なので、AOF書き換えが登場しました。これは非常に単純で、まずデータベースから現在の値を読み取り、それをレコードに置き換えるという、AOF 書き換えの原理です。書き換えには時間がかかるため、子プロセスで処理します。書き換えプロセス中に、新しいコマンドが来た場合はどうすればよいでしょうか? 古い方法では、buf バッファーに書き込みます。書き換えが完了したら、buf 内のコマンドを新しい aof に追加し、古い aof をnew aof. 書き換えを実装しました。

この記事は

redis チュートリアル から引用したものです。ぜひ学習してください。

以上がRedis で永続性を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Redis vs.その他のデータベース:比較分析Redis vs.その他のデータベース:比較分析Apr 23, 2025 am 12:16 AM

他のデータベースと比較して、Redisには次の独自の利点があります。1)非常に速い速度、および読み取り操作は通常、マイクロ秒レベルにあります。 2)豊富なデータ構造と操作をサポートします。 3)キャッシュ、カウンター、公開サブスクリプションなどの柔軟な使用シナリオ。 Redisまたはその他のデータベースを選択する場合、特定のニーズとシナリオに依存します。 Redisは、高性能および低遅延のアプリケーションでうまく機能します。

Redisの役割:データストレージと管理機能の調査Redisの役割:データストレージと管理機能の調査Apr 22, 2025 am 12:10 AM

Redisは、データストレージと管理において重要な役割を果たしており、複数のデータ構造と持続性メカニズムを通じて最新のアプリケーションの中核となっています。 1)Redisは、文字列、リスト、コレクション、注文されたコレクション、ハッシュテーブルなどのデータ構造をサポートし、キャッシュや複雑なビジネスロジックに適しています。 2)RDBとAOFの2つの持続方法を通じて、Redisは信頼できるストレージとデータの迅速な回復を保証します。

Redis:NOSQLの概念の理解Redis:NOSQLの概念の理解Apr 21, 2025 am 12:04 AM

Redisは、大規模なデータの効率的なストレージとアクセスに適したNOSQLデータベースです。 1.Redisは、複数のデータ構造をサポートするオープンソースメモリデータ構造ストレージシステムです。 2.キャッシュ、セッション管理などに適した、非常に速い読み取り速度と書き込み速度を提供します。 4.使用例には、基本的なキー値ペア操作と高度なコレクション重複排除関数が含まれます。 5.一般的なエラーには、接続の問題、データ型の不一致、メモリオーバーフローが含まれるため、デバッグに注意する必要があります。 6.パフォーマンス最適化の提案には、適切なデータ構造の選択とメモリ排除戦略の設定が含まれます。

Redis:実際のユースケースと例Redis:実際のユースケースと例Apr 20, 2025 am 12:06 AM

現実世界でのRedisのアプリケーションには、1。キャッシュシステムとして、データベースクエリを加速し、2。Webアプリケーションのセッションデータを保存するには、3。リアルタイムランキングを実装する4。メッセージ配信をメッセージキューとして簡素化する。 Redisの汎用性と高性能により、これらのシナリオで輝きます。

Redis:その機能と機能の調査Redis:その機能と機能の調査Apr 19, 2025 am 12:04 AM

Redisは、高速、汎用性、豊富なデータ構造のために際立っています。 1)Redisは、文字列、リスト、コレクション、ハッシュなどのデータ構造をサポートし、コレクションを注文します。 2)メモリを介してデータを保存し、RDBとAOFの持続性をサポートします。 3)Redis 6.0から始めて、マルチスレッドI/O操作が導入されました。これにより、高い並行性シナリオでパフォーマンスが向上しました。

RedisはSQLまたはNOSQLデータベースですか?答えが説明しましたRedisはSQLまたはNOSQLデータベースですか?答えが説明しましたApr 18, 2025 am 12:11 AM

redisisclassifiedsaNosqldatabasebasesakey-valuedataModelinsteaded ofthetraditionaldatabasemodel.itoffersspeedand andffficability、makingidealforreal-timeaplications andcaching、butmaynotbesbesutable fors cenariois requiring datientiantientioniity

Redis:アプリケーションのパフォーマンスとスケーラビリティの向上Redis:アプリケーションのパフォーマンスとスケーラビリティの向上Apr 17, 2025 am 12:16 AM

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

Redis:データモデルと構造の調査Redis:データモデルと構造の調査Apr 16, 2025 am 12:09 AM

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

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。