一、Master&Slave是什麼?
也就是我們所說的主從複製,主機資料更新後根據配置和策略,自動同步到備機的master/slaver機制,Master以寫為主,Slave以讀為主。
二、它能幹嘛?
1、讀寫分離;
2、容災復原。
三、怎麼玩?
1、配從(庫)不配主(庫);
2、從庫配置:slaveof [主庫IP] [主庫連接埠];
補充:每次slave與master斷開後,都需要重新連接,除非你配置進redis.conf檔;
鍵入info replication 可以查看redis主從資訊.
3、修改設定檔細節操作
- 拷貝多個redis.conf檔
- 指定連接埠
- 開啟daemonize yes
- Pid檔名
- Log檔案名稱
- Dump.rdb名字
4、常用3招
- 一主二僕
一個Master,兩個Slave,Slave只能讀不能寫;當Slave與Master斷開後需要重新slave of連接才可建立之前的主從關係;Master掛掉後,Master關係依然存在,Master重啟即可恢復。
- 薪火相傳
上一個Slave可以是下一個Slave的Master,Slave同樣可以接收其他slaves的連接和同步請求,那麼該slave作為了鏈條中下一個slave的Master,如此可以有效減輕Master的寫壓力。如果從伺服器在中途更改了資料同步的主伺服器,則舊資料將會清除並重新建立與最新主伺服器的同步。
- 反客為主
當Master掛掉後,Slave可鍵入指令 slaveof no one使目前redis停止與其他Master redis資料同步,轉成Master redis。
四、複製原理
1、Slave啟動成功連線到master後會發送一個sync指令;
2、Master接到指令啟動後的記憶體進程,同時收集所有接收到的用於修改資料集指令,在後台程序執行完畢之後,master 將傳送整個資料檔到slave,以完成一次完全同步;
3、全量複製:而slave服務在資料庫文件資料後,將其記憶體並載入到記憶體中;
4、增量複製:Master繼續將新的所有收集到的修改命令依次傳給slave,完成同步;
5.但是只要是重新連線master,一次完全同步(全量複製)就會自動執行。
五、哨兵模式(sentinel)
反客為主的自動版,能夠後台監控Master庫是否有故障,如果故障了根據投票數自動將slave庫轉換為主函式庫。一組sentinel能同時監控多個Master。
使用步驟:
1、在Master對應redis.conf同目錄下新建sentinel.conf文件,名字絕對不能錯;
2 、設定哨兵,在sentinel.conf檔案中填入內容:
sentinel monitor 被監控資料庫名稱(自己取名字) ip port 1
#說明:上面最後一個數字1,表示主機掛掉後slave投票看讓誰接替成為主機,得票數多少後成為主機。
3、啟動哨兵模式:
指令鍵入:redis-sentinel /myredis/sentinel.conf
-
#附註:上述sentinel.conf路徑依各自實際情況配置
六、複製的缺點
延時,由於所有的寫入操作都是在Master上操作,然後同步更新到Slave上,所以從Master同步到Slave機器有一定的延遲,當系統很繁忙的時候,延遲問題會更加嚴重,Slave機器數量的增加也會使得這個問題更加嚴重。
Redis master, slave節點部署詳解
1. 建立兩個redis.conf檔, 一主一從
redis_6379.conf redis_6380.conf
2. master conf 主要設定
bind 127.0.0.1 port 6379 protected-mode yes daemonize yes pidfile /var/run/redis_6379.pid logfile "/Data/apps/redis-3.2.12/logs/redis_6379.log" dbfilename dump_6379.rdb dir /Data/apps/redis-3.2.12/workplace requirepass paopao
3. slave conf 主要配置
bind 127.0.0.1 port 6380 protected-mode yes daemonize yes pidfile /var/run/redis_6380.pid logfile "/Data/apps/redis-3.2.12/logs/redis_6380.log" dbfilename dump_6380.rdb dir /Data/apps/redis-3.2.12/workplace slaveof 127.0.0.1 6379 masterauth paopao
4. 啟動主從redis-server進程
redis-server /Data/apps/redis-3.2.12/conf/redis_6379.conf redis-server /Data/apps/redis-3.2.12/conf/redis_6380.conf
5.其他相關設定
# 当从库同主机失去连接或者复制正在进行,从机库有两种运行方式: # 1) 如果slave-serve-stale-data设置为yes(默认设置),从库会继续相应客户端的请求 # 2) 如果slave-serve-stale-data是指为no,除去INFO和SLAVOF命令之外的任何请求都会返回一个 # 错误"SYNC with master in progress" slave-serve-stale-data yes slave-read-only yes # 从库会按照一个时间间隔向主库发送PINGs.可以通过repl-ping-slave-period设置这个时间间隔,默认是10秒 repl-ping-slave-period 10 # repl-timeout 设置主库批量数据传输时间或者ping回复时间间隔,默认值是60秒 # 一定要确保repl-timeout大于repl-ping-slave-period repl-timeout 60 # slave节点磁盘慢, 网速快时, 置为yes, master上的rdb文件将以socket方式传输, 跳过磁盘存储 repl-diskless-sync no # 传输前等待秒数, 为了等待更多的slave节点加入 repl-diskless-sync-delay 5 # 传输时,是否禁用tcp nodelay repl-disable-tcp-nodelay no # 复制缓冲区大小 repl-backlog-size 1mb # 复制缓冲区释放周期 repl-backlog-ttl 3600 # 为了sentinal模式, 选举master准备, 数值越小, 优先级越高 slave-priority 100 # require at least 3 slaves with a lag <= 10 seconds use min-slaves-to-write 3 min-slaves-max-lag 10 # 可覆盖bind, port 配置, 对外ip port slave-announce-ip 5.5.5.5 slave-announce-port 1234
以上是Redis實現主從複製的方法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Redis的數據庫方法包括內存數據庫和鍵值存儲。 1)Redis將數據存儲在內存中,讀寫速度快。 2)它使用鍵值對存儲數據,支持複雜數據結構,如列表、集合、哈希表和有序集合,適用於緩存和NoSQL數據庫。

Redis是一個強大的數據庫解決方案,因為它提供了極速性能、豐富的數據結構、高可用性和擴展性、持久化能力以及廣泛的生態系統支持。 1)極速性能:Redis的數據存儲在內存中,讀寫速度極快,適合高並發和低延遲應用。 2)豐富的數據結構:支持多種數據類型,如列表、集合等,適用於多種場景。 3)高可用性和擴展性:支持主從復制和集群模式,實現高可用性和水平擴展。 4)持久化和數據安全:通過RDB和AOF兩種方式實現數據持久化,確保數據的完整性和可靠性。 5)廣泛的生態系統和社區支持:擁有龐大的生態系統和活躍社區,

Redis的關鍵特性包括速度、靈活性和豐富的數據結構支持。 1)速度:Redis作為內存數據庫,讀寫操作幾乎瞬時,適用於緩存和會話管理。 2)靈活性:支持多種數據結構,如字符串、列表、集合等,適用於復雜數據處理。 3)數據結構支持:提供字符串、列表、集合、哈希表等,適合不同業務需求。

Redis的核心功能是高性能的內存數據存儲和處理系統。 1)高速數據訪問:Redis將數據存儲在內存中,提供微秒級別的讀寫速度。 2)豐富的數據結構:支持字符串、列表、集合等,適應多種應用場景。 3)持久化:通過RDB和AOF方式將數據持久化到磁盤。 4)發布訂閱:可用於消息隊列或實時通信系統。

Redis支持多種數據結構,具體包括:1.字符串(String),適合存儲單一值數據;2.列表(List),適用於隊列和棧;3.集合(Set),用於存儲不重複數據;4.有序集合(SortedSet),適用於排行榜和優先級隊列;5.哈希表(Hash),適合存儲對像或結構化數據。

Redis計數器是一種使用Redis鍵值對存儲來實現計數操作的機制,包含以下步驟:創建計數器鍵、增加計數、減少計數、重置計數和獲取計數。 Redis計數器的優勢包括速度快、高並發、持久性和簡單易用。它可用於用戶訪問計數、實時指標跟踪、遊戲分數和排名以及訂單處理計數等場景。

使用 Redis 命令行工具 (redis-cli) 可通過以下步驟管理和操作 Redis:連接到服務器,指定地址和端口。使用命令名稱和參數向服務器發送命令。使用 HELP 命令查看特定命令的幫助信息。使用 QUIT 命令退出命令行工具。

Redis集群模式通過分片將Redis實例部署到多個服務器,提高可擴展性和可用性。搭建步驟如下:創建奇數個Redis實例,端口不同;創建3個sentinel實例,監控Redis實例並進行故障轉移;配置sentinel配置文件,添加監控Redis實例信息和故障轉移設置;配置Redis實例配置文件,啟用集群模式並指定集群信息文件路徑;創建nodes.conf文件,包含各Redis實例的信息;啟動集群,執行create命令創建集群並指定副本數量;登錄集群執行CLUSTER INFO命令驗證集群狀態;使


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

記事本++7.3.1
好用且免費的程式碼編輯器

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

WebStorm Mac版
好用的JavaScript開發工具