這篇文章給大家了解一下Redis中的主從複製,介紹一下主從基本配置、主從配置的作用和原理,希望對大家有所幫助!
Redis支援主從複製功能,可以透過執行slaveof(Redis5版本以後改成replicaof)或是在設定檔中設定slaveof(Redis5版本以後改成replicaof)來開啟複製功能。 【相關推薦:Redis影片教學】
# salve的端口号 port 6380 #把pid进程号写入pidfile配置的文件 pidfile /var/run/redis_6380.pid logfile "6380.log" #指定数据存放目录 dir /usr/local/redis‐5.0.3/data/6380 #需要注释掉bind #bind127.0.0.1(bind绑定的是自己机器网卡的ip,如果有多块网卡可以配多个ip,代表允许客户端通过机器的哪些网卡ip去访问,内网一般可以不配置bind,注释掉即可)
#从本机master6379的redis实例复制数据,Redis5.0之前使用slaveof replicaof 192.168.0.60 6379 #配置从节点只读 replica‐read‐only yes
redis‐server redis.conf
redis‐cli ‐p 6380
docker run --name redis-6381 -v /Users/yujiale/docker/redis/conf/redis6381.conf:/etc/redis/redis.conf -v /Users/yujiale/docker/redis/conf/sentinel6381.conf:/etc/redis/sentine.conf -v /Users/yujiale/docker/redis/data6381:/data --network localNetwork --ip 172.172.0.14 -p 16381:6379 -d redis:6.2.6 redis-server /etc/redis/redis.conf --appendonly yes
slaver關聯檔案事件處理器
該處理器接收RDB檔案(全量複製)、接收Master傳播來的寫指令(增量複製)權限驗證
主從正常連線後,進行權限驗證
或從透過auth指令傳送密碼
從節點接收到rdb快照後清空老數據,並載入rdb檔案
同步寫入緩衝階段:Master向Slave同步儲存在緩衝區的寫入操作命令。
從節點接收buffer快取文件,並載入buffer快取檔案到記憶體中
從Redis接收到主Redis發送過來的命令,執行當前命令
如果你為master配置了一個slave,不管這個slave是否是第一次連接上Master,它都會發送一個PSYNC指令給master請求複製資料。 master收到PSYNC指令後,會在後台進行資料持久化透過bgsave產生最新的rdb快照文件,持久化期間,master會繼續接收客戶端的請求,它會把這些可能修改資料集的請求快取在記憶體中。當持久化進行完畢以後,master會把這份rdb檔案資料集傳送給slave,slave會把接收到的資料持久化產生rdb,然後再載入到記憶體中。然後,master再將先前快取在記憶體中的指令傳送給slave。當master與slave之間的連接由於某些原因而斷開時,slave能夠自動重連Master,如果master收到了多個slave並發連接請求,它只會進行一次持久化,而不是一個連接一次,然後再把這份持久化的資料傳送給多個並發連線的slave。
#大體流程跟全量複製差不多,就不過多講解
當master和slave斷開重連後,一般都會對整個資料進行複製。但從redis2.8版本開始,redis改用可以支援部分資料複製的指令PSYNC去master同步數據,slave與master能夠在網路連線斷開重連後只進行部分資料複製(斷點續傳)。 master會在其內存中創建一個複製數據用的緩存隊列,緩存最近一段時間的數據,master和它所有的slave都維護了複製的數據下標offset和master的進程id,因此,當網絡連接斷開後,slave會請求master繼續進行未完成的複製,從所記錄的資料下標開始。如果master進程id變化了,或是從節點資料下標offset太舊,已經不在master的快取佇列裡了,那麼將會進行一次全量資料的複製。主從複製(部分複製,斷點續傳)流程圖:
#客戶端發送saveof後主節點會判斷是否第一次複製,如果是則進行全量複製,如果不是透過runid offset偏移量進行判斷是否一致,如果一致則進行部分複製,否則進行全量複製。
更多程式相關知識,請造訪:程式設計影片! !
以上是詳細了解Redis中的主從複製的詳細內容。更多資訊請關注PHP中文網其他相關文章!