是什麼
#行話:也就是我們所說的主從複製,主機資料更新後根據配置和策略, 自動同步到備機的master/slaver機制,Master以寫為主,Slave以讀為主
能幹嘛
#讀寫分離
災難復原
推薦(免費):redis
怎麼玩
•配從(庫)不配主(庫)
• 從庫配置命令:slaveof 主庫IP 主庫端口
• 每次與master斷開之後,都需要重新連接,除非你配置進redis.conf文件(具體位置:redis.conf搜尋
# REPLICATION
#)
• info replication
• 修改設定檔細節操作
• 拷貝多個redis.conf檔,按'redis[ port].conf'重命名
• 開啟daemonize yes
• pid檔名
• 指定連接埠
## ••名字名稱檔案名稱
# 她名字名字。 #replication 英[ˌreplɪ'keɪʃ(ə)n] 美[ˌreplɪ'keɪʃ(ə)n] n.
(繪畫等的)複製;拷貝;重複(實驗);(尤指對答辯的)回答
常用3招
一主二僕(一台主機,兩台從機)
Init
透過slaveof 127.0.0.1 6379d來設定僕機
此時設定了一主二僕
在主的裡面set k4 v4,在兩個slave裡面get k4都能顯示出來。
1.如果再slave之前,我設定了k1和k2.那麼從機能否查的出來其值?
2.此時在主機上面set k6 v6.而兩個從機上面也有set k6 v66.此時會出現哪種情況。先到先得,後者覆蓋,從機和主機執行同樣的命令是否可以通過? 主機寫為主,從機讀為主 此時從機不能寫,報了異常。
3.主機死了?從機會有哪些情況。從機上位?原地待命? 還是slave,原地待命。不會上位,領導回來了,一切照舊
4.從機死了?從機能不能恢復?
從機死了,恢復過來就變成了master,因為• 每次與master斷開之後,都需要重新連接,除非你配置進redis.conf。如果想跟上大部隊,就是用slaveof指令即可。從頭來一遍,把主機的從頭到尾擼一遍。
薪火相傳
核心思想:去中心化
上一個Slave可以是下一個slave的Master,Slave同樣可以接收其他slaves的連接和同步請求,那麼該slave作為了鏈條中下一個的master, 可以有效減輕master的寫壓力(奴隸的奴隸還是奴隸)
中途變更轉向:會清除之前的數據,重新建立拷貝最新的
slaveof 新主庫IP 新主庫埠
79是80的主機,80是81的主機。在79中set k9 v9在80和81之間都能查詢的到,在80主機上使用info republication,是slave,但是也連接了一個slaver。
反客為主
SLAVEOF no one讓目前資料庫停止與其他資料庫的同步,轉成主資料庫
主機掛了之後,兩個從機需要選擇出一個老大,這時候對80使用一個指令,slaveof no one,讓80稱為領導。而對於81來說,如果使用了slaveof 80,則認80位元主機,對80的資料做了修改,81也能夠查詢的到。若原主機79回來了之後,此時就變成了一個獨立的個體。複製原理
slave啟動成功連線到master後會發送一個sync指令master接到指令啟動後台的記憶體進程,同時收集所有接收到的用於修改資料集命令, 在後台進程執行完畢之後,master將傳送整個資料檔案到slave,以完成一次完全同步 全量複製:而slave服務在接收到資料庫檔案資料後,將其儲存並載入到記憶體中。 增量複製:Master繼續將新的所有收集到的修改命令依次傳給slave,完成同步
但是只要是重新連接master,一次完全同步(全量複製)將被自動執行### 首次是全量複製,其後是增量複製。 #########哨兵模式(sentinel)#########一組sentinel能同時監控多個master(巡邏放哨)#########是什麼### ######反客為主的自動版,能夠後台監控主機是否故障,如果故障了根據投票數自動將從庫轉換為主庫#########怎麼玩(使用步驟)### ### 1. 調整結構,6379帶著6380、6381
2. 新建sentinel.conf文件,名字絕不能錯
3. 配置哨兵,填寫內容
1.sentinel monitor 被監控資料庫名稱(自己取名字) 127.0.0.1 6379 1
2. 上面最後一個數字1,表示主機掛掉後salve投票看讓誰接替成為主機,得票數多少後成為主機(PS. 跟官網的描述有出入官網的描述有出入官,下面有官方文件說明)
4. 啟動哨兵
1. redis-sentinel /sentinel.conf(上述目錄依照各自的實際情況配置,可能目錄不同)
5. 正常主從演示
6. 原有的master掛了
7.投票新選
8. 重新主從繼續開工,info replication查查看
#問題:如果之前掛了的master重啟回來,會不會雙master衝突?
答: 不會,原master,變成slave
複製的缺點
#複製延時
由於所有的寫入操作都是先在Master上操作,然後同步更新到slave上,所以從Master同步到Slave機器有一定的延遲,當系統很繁忙的時候,延遲問題會更加嚴重,Slave機器數量的增加也會使這個問題更加嚴重。
更多相關免費學習推薦:redis教學
以上是redis學習主從複製Master/slave的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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命令驗證集群狀態;使

要從 Redis 讀取隊列,需要獲取隊列名稱、使用 LPOP 命令讀取元素,並處理空隊列。具體步驟如下:獲取隊列名稱:以 "queue:" 前綴命名,如 "queue:my-queue"。使用 LPOP 命令:從隊列頭部彈出元素並返回其值,如 LPOP queue:my-queue。處理空隊列:如果隊列為空,LPOP 返回 nil,可先檢查隊列是否存在再讀取元素。

Redis 集群中使用 zset:zset 是一種有序集合,將元素與評分關聯。分片策略: a. 哈希分片:根據 zset 鍵的哈希值分佈。 b. 範圍分片:根據元素評分劃分為範圍,並將每個範圍分配給不同的節點。讀寫操作: a. 讀操作:如果 zset 鍵屬於當前節點的分片,則在本地處理;否則,路由到相應的分片。 b. 寫入操作:始終路由到持有 zset 鍵的分片。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)