永続性の概要
RDB
AOF
RDB と AOF
の違い永続化アプリケーションのシナリオ
永続化関数の場合、実際には非常に単純であり、それほど複雑ではありません
##1. 永続性の概要
redis 内のすべてのデータはメモリに保存されるため、redis がクラッシュするとデータが失われます。 Redis の永続化とは、データをディスクに保存することです。永続的なストレージ メディアを使用してデータ プロセスを保存し、特定の時点で保存されたデータを復元する動作メカニズムは、永続性と呼ばれます。
永続化プロセスでは何が保存されますか?
##2. RDB
2-1 RDB起動モード -- コマンドの保存
以下の図はredis.confの設定情報です。実行後 保存後、dump.rdb ファイルが生成されます。
#値を設定して、/usr/local/redis に保存します。 /data ファイル dump6379.rdb が存在します。
実は、他のリレーショナル データベース復旧と比較して、このデータ復旧は基本的に操作が必要ありません。再起動してください
保存を実行すると、 Redis を要求する他のクライアントからの命令は、保存命令が完了するまで待機します。保存命令はシングルスレッドで実行されるため、実行時間が長すぎると、他のユーザーが正常にデータを保存できなくなる原因となります。したがって、このコマンドはデフォルトでは放棄されます。以下で紹介する bgsave が代わりに使用されます
bgsave が Redis で実行される場合バックグラウンド保存が開始されたことを直接返します
#2-5 RDB -- 設定ファイルの自動起動
以下配置是默认配置 save 900 1 save 300 10 save 60 10000 stop-writes-on-bgsave-error yes
#save [時間] [キー変更量]
##3. AOF
3-1 AOF の概念
3-2 AOFデータ書き込み処理
#redis コマンドを実行します
##redis の AOF によってコマンド バッファーが更新されます
その後、特定の方法に従って redis.conf に設定された .aof ファイルに同期します
3-3 AOF 書き込みデータ 3 つの戦略
##常に: 実行されたコマンドは AOF ファイルに保存されますが、データ エラーはなく、パフォーマンスは低下します。
3-4 AOF 機能がオンになりました
appendonly yes|no
appendfsync always| Everysec | no
次に、redis サービスを再起動します。usr/local/redis/ を使用できます。 data ディレクトリ 以下に appendonly.aof ファイルが表示されます。
次に、redis クライアントでコマンドを実行してチェックアウトします。データが appendonly.aof ファイルに保存されることがわかります。
#たとえば、上記では set name コマンドを 3 回実行しましたが、最終的に必要なのは最後の実行の記録だけです。つまり、最後の実行レコードのみが必要です。他のレコードは必要なく、圧縮データは aof ファイルに書き換えられます。
書き換え後、ディスク使用率が向上しました
また、データ復旧の速度も速くなります
永続化の効率も向上します
。また、「3-5. キーに対する連続操作」で述べた問題もあります。
lpush list a b c に変換できます。
#3-8 AOF 手動書き換え
コマンド:
質問 3 ~ 5 に従って、コマンド ラインで bgrewriteaof コマンドを実行し、appendonly.aof ファイルを表示します
実行後、ファイルが小さくなり、ファイル内に命令が 1 つしかないことがわかります。
##3-10 AOF 自動書き換え
auto -aof-rewrite-percentage 100 | auto-aof-rewrite-min-size 64mb
トリガー比較パラメーター: aof_current_size | aof_base_size
##
いつ aof_current_size > auto-aof-rewrite-min-size 64mb が書き換えを開始するか
この画像はインターネットからのものです
## 以上が Redis 永続化の内容のすべてです。 4. 概要
以上がRedis 永続化のフルバージョンの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。