検索
ホームページデータベースRedisRedis がデータを永続化する仕組み

Redis は、RDB (Redis DataBase) と AOF (Apend Only File) という 2 つのデータ永続化方式を提供します。

Redis がデータを永続化する仕組み

#RDB 方式

RDB 方式は、ある時点のデータを保存するスナップショット永続化方式です。 。 (推奨学習:

Redis ビデオ チュートリアル )

データ永続化のプロセス中、Redis は最初にデータを一時ファイルに書き込み、永続化プロセスが完了すると、この一時ファイルは最後に保存されたファイルを置き換えるために使用されます。スナップショット ファイルは常に完全に利用できるため、いつでもバックアップを実行できるのはこの機能です。

RDB モードの場合、redis は永続化のために子プロセスを個別に作成 (フォーク) し、メイン プロセスは IO 操作を実行しないため、redis の非常に高いパフォーマンスが保証されます。

大規模なデータ リカバリが必要で、データ リカバリの整合性がそれほど重要でない場合は、RDB 方式の方が AOF 方式よりも効率的です。

AOF メソッド

AOF メソッドは、実行された書き込み命令を記録し、データ回復中にその命令を前から後ろに順番に実行します。

AOF コマンドは、redis プロトコルを使用して、各書き込み操作をファイルの末尾に追加して保存します。 Redis は、AOF ファイルのサイズが大きくなりすぎないように、バックグラウンドで AOF ファイルを書き換えることもできます。

デフォルトの AOF 永続化戦略は、1 秒に 1 回 fsync です (fsync とは、キャッシュ内の書き込み命令をディスクに記録することを指します)。この場合、redis が失敗した場合でも、redis は良好な処理パフォーマンスを維持できるためです。最後の 1 秒のデータのみが失われます。

ログを追加するときに、ディスク容量がいっぱい、inode がいっぱい、または停電が発生してログの書き込みが不完全になっても、問題はありません。Redis には redis-check-aof ツールが用意されています。ログ修復を実行できます。

追記方式のため、何も処理をしないとAOFファイルがどんどん大きくなってしまうため、redisではAOFファイルの書き換え(リライト)機構を提供しています。 AOF ファイル 設定されたしきい値を超えると、redis は AOF ファイルのコンテンツ圧縮を開始し、データを回復できる最小限の命令セットのみを保持します。

例はもっとわかりやすいかもしれません。INCR 命令を 100 回呼び出すと、100 個の命令が AOF ファイルに保存されますが、これは明らかに非常に非効率です。これらの 100 個の命令はマージできます。SET 命令に、これが書き換えメカニズムの原理です。

AOF を書き換える場合、最初に一時ファイルを書き込んでから一時ファイルを置き換えるプロセスが引き続き使用されるため、停電やディスク容量不足などの問題は AOF ファイルの可用性に影響しません。

Redis 関連の技術記事の詳細については、

Redis 入門チュートリアル 列にアクセスして学習してください。

以上がRedis がデータを永続化する仕組みの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
es和redis区别es和redis区别Jul 06, 2019 pm 01:45 PM

Redis是现在最热门的key-value数据库,Redis的最大特点是key-value存储所带来的简单和高性能;相较于MongoDB和Redis,晚一年发布的ES可能知名度要低一些,ES的特点是搜索,ES是围绕搜索设计的。

一起来聊聊Redis有什么优势和特点一起来聊聊Redis有什么优势和特点May 16, 2022 pm 06:04 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于redis的一些优势和特点,Redis 是一个开源的使用ANSI C语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式存储数据库,下面一起来看一下,希望对大家有帮助。

实例详解Redis Cluster集群收缩主从节点实例详解Redis Cluster集群收缩主从节点Apr 21, 2022 pm 06:23 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis Cluster集群收缩主从节点的相关问题,包括了Cluster集群收缩概念、将6390主节点从集群中收缩、验证数据迁移过程是否导致数据异常等,希望对大家有帮助。

Redis实现排行榜及相同积分按时间排序功能的实现Redis实现排行榜及相同积分按时间排序功能的实现Aug 22, 2022 pm 05:51 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,希望对大家有帮助。

详细解析Redis中命令的原子性详细解析Redis中命令的原子性Jun 01, 2022 am 11:58 AM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于原子操作中命令原子性的相关问题,包括了处理并发的方案、编程模型、多IO线程以及单命令的相关内容,下面一起看一下,希望对大家有帮助。

实例详解Redis实现排行榜及相同积分按时间排序功能的实现实例详解Redis实现排行榜及相同积分按时间排序功能的实现Aug 26, 2022 pm 02:09 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,下面一起来看一下,希望对大家有帮助。

一文搞懂redis的bitmap一文搞懂redis的bitmapApr 27, 2022 pm 07:48 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了bitmap问题,Redis 为我们提供了位图这一数据结构,位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已,希望对大家有帮助。

redis error什么意思redis error什么意思Jun 17, 2019 am 11:07 AM

redis error就是redis数据库和其组合使用的部件出现错误,这个出现的错误有很多种,例如Redis被配置为保存数据库快照,但它不能持久化到硬盘,用来修改集合数据的命令不能用。

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

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

mPDF

mPDF

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