1. Redis のレプリケーション:
ここで最初に説明する必要があるのは、Redis でのマスター/スレーブ モードの構成は非常に簡単であるということです。このブログを読んでいただければ簡単にできると思います。ここでは、最初にいくつかの理論的な知識を列挙し、次に実際の事例を示します。
次のリストは、Redis レプリケーションの機能と利点を明確に説明しています。
1) 同じマスターは複数のスレーブを同期できます。
2). スレーブは他のスレーブからの接続および同期リクエストも受け入れることができるため、マスターの同期プレッシャーを効果的に軽減できます。したがって、Redis のレプリケーション アーキテクチャはグラフ構造として考えることができます。
3). マスターサーバーは、ノンブロッキング方式でスレーブにサービスを提供します。したがって、マスターとスレーブの同期中も、クライアントはクエリまたは変更リクエストを送信できます。
4). スレーブサーバーも非ブロッキング方式でデータ同期を完了します。同期中にクライアントがクエリリクエストを送信すると、Redis は同期前にデータを返します。
5). マスターの読み取り操作の負荷を軽減するために、スレーブ サーバーは読み取り専用操作サービスをクライアントに提供できますが、書き込みサービスはマスターによって完了する必要があります。それでも、システムの拡張性は大幅に向上しました。
6). マスターはデータ保存操作をスレーブに引き渡すことができるため、この操作を完了するためにマスター内の独立したプロセスが必要なくなります。
2. レプリケーションの仕組み:
スレーブが起動してマスターに接続すると、SYNC コマンドがアクティブに送信されます。その後、マスターはバックグラウンド保存プロセスを開始し、データ セットを変更するために受信したすべてのコマンドを収集します。バックグラウンド プロセスが完了すると、マスターはデータベース ファイル全体をスレーブに転送して完全な同期を完了します。データベース ファイル データを受信した後、スレーブ サーバーはそれを保存し、メモリにロードします。その後、マスターは収集したすべての変更コマンドと新しい変更コマンドを順番にスレーブに送信し続け、今度はスレーブがこれらのデータ変更コマンドを実行して、最終的なデータ同期を達成します。
マスターとスレーブ間のリンクが切断された場合、スレーブは自動的にマスターに再接続できますが、接続が成功すると、完全な同期が自動的に実行されます。
3. レプリケーションを構成する方法:
次の手順を参照してください:
1). 同じマシン上で 2 つの Redis サーバーを同時に起動し、6379 や 6379 などの異なるポートをリッスンすることを検討できます。 6380。
2). スレーブ サーバーでコマンドを実行します:
/> redis-cli -p 6380 #这里我们假设Slave的端口号是6380 redis 127.0.0.1:6380> slaveof 127.0.0.1 6379 #我们假设Master和Slave在同一台主机,Master的端口为6379 OK
上記の方法は、slaveof コマンドの実行後に、redis_6380 が redis_6379 のスレーブになることを保証するだけであり、サービス (redis_6380) が再起動されると、それらの間のレプリケーション関係が終了します。 。
2 つのサーバー間のレプリケーション関係を長期間確保したい場合は、redis_6380 の構成ファイルに次の変更を加えることができます:
/> cd /etc/redis #切换Redis服务器配置文件所在的目录。 /> ls 6379.conf 6380.conf /> vi 6380.conf 将 # slaveof <masterip> <masterport> 改为 slaveof 127.0.0.1 6379
保存して終了します。
これにより、Redis_6380 サービス プログラムが各起動後に Redis_6379 とのレプリケーション接続をアクティブに確立するようになります。
4. 応用例:
ここでは、マスターとスレーブが確立されていると仮定します。
#启动master服务器。 [root@Stephen-PC redis]# redis-cli -p 6379 redis 127.0.0.1:6379> #情况Master当前数据库中的所有Keys。 redis 127.0.0.1:6379> flushdb OK #在Master中创建新的Keys作为测试数据。 redis 127.0.0.1:6379> set mykey hello OK redis 127.0.0.1:6379> set mykey2 world OK #查看Master中存在哪些Keys。 redis 127.0.0.1:6379> keys * 1) "mykey" 2) "mykey2" #启动slave服务器。 [root@Stephen-PC redis]# redis-cli -p 6380 #查看Slave中的Keys是否和Master中一致,从结果看,他们是相等的。 redis 127.0.0.1:6380> keys * 1) "mykey" 2) "mykey2" #在Master中删除其中一个测试Key,并查看删除后的结果。 redis 127.0.0.1:6379> del mykey2 (integer) 1 redis 127.0.0.1:6379> keys * 1) "mykey" #在Slave中查看是否mykey2也已经在Slave中被删除。 redis 127.0.0.1:6380> keys * 1) "mykey"
上記は Redis チュートリアル (9): マスター/スレーブ コピーの構成例の内容です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) に注目してください。

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

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

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

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

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

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

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

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于实现秒杀的相关内容,包括了秒杀逻辑、存在的链接超时、超卖和库存遗留的问题,下面一起来看一下,希望对大家有帮助。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
