日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

redis 主从复制 [转]

發(fā)布時(shí)間:2023/12/19 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 redis 主从复制 [转] 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、Redis的Replication:

?? ?這里首先需要說(shuō)明的是,在Redis中配置Master-Slave模式真是太簡(jiǎn)單了。相信在閱讀完這篇Blog之后你也可以輕松做到。這里我們還是先列出一些理論性的知識(shí),后面給出實(shí)際操作的案例。
?? ?下面的列表清楚的解釋了Redis Replication的特點(diǎn)和優(yōu)勢(shì)。
?? ?1). 同一個(gè)Master可以同步多個(gè)Slaves。
?? ?2). Slave同樣可以接受其它Slaves的連接和同步請(qǐng)求,這樣可以有效的分載Master的同步壓力。因此我們可以將Redis的Replication架構(gòu)視為圖結(jié)構(gòu)。
?? ?3). Master Server是以非阻塞的方式為Slaves提供服務(wù)。所以在Master-Slave同步期間,客戶端仍然可以提交查詢或修改請(qǐng)求。
?? ?4). Slave Server同樣是以非阻塞的方式完成數(shù)據(jù)同步。在同步期間,如果有客戶端提交查詢請(qǐng)求,Redis則返回同步之前的數(shù)據(jù)。
?? ?5). 為了分載Master的讀操作壓力,Slave服務(wù)器可以為客戶端提供只讀操作的服務(wù),寫(xiě)服務(wù)仍然必須由Master來(lái)完成。即便如此,系統(tǒng)的伸縮性還是得到了很大的提高。
?? ?6). Master可以將數(shù)據(jù)保存操作交給Slaves完成,從而避免了在Master中要有獨(dú)立的進(jìn)程來(lái)完成此操作。
?? ?
二、Replication的工作原理:

?? ?在Slave啟動(dòng)并連接到Master之后,它將主動(dòng)發(fā)送一個(gè)SYNC命令。此后Master將啟動(dòng)后臺(tái)存盤(pán)進(jìn)程,同時(shí)收集所有接收到的用于修改數(shù)據(jù)集的命令,在后臺(tái)進(jìn)程執(zhí)行完畢后,Master將傳送整個(gè)數(shù)據(jù)庫(kù)文件到Slave,以完成一次完全同步。而Slave服務(wù)器在接收到數(shù)據(jù)庫(kù)文件數(shù)據(jù)之后將其存盤(pán)并加載到內(nèi)存中。此后,Master繼續(xù)將所有已經(jīng)收集到的修改命令,和新的修改命令依次傳送給Slaves,Slave將在本次執(zhí)行這些數(shù)據(jù)修改命令,從而達(dá)到最終的數(shù)據(jù)同步。
?? ?如果Master和Slave之間的鏈接出現(xiàn)斷連現(xiàn)象,Slave可以自動(dòng)重連Master,但是在連接成功之后,一次完全同步將被自動(dòng)執(zhí)行。
?? ?
三、如何配置Replication:

?? ?見(jiàn)如下步驟:
?? ?1). 同時(shí)啟動(dòng)兩個(gè)Redis服務(wù)器,可以考慮在同一臺(tái)機(jī)器上啟動(dòng)兩個(gè)Redis服務(wù)器,分別監(jiān)聽(tīng)不同的端口,如6379和6380。
?? ?2). 在Slave服務(wù)器上執(zhí)行一下命令:
????/>?redis-cli -p 6380???#這里我們假設(shè)Slave的端口號(hào)是6380
?? ?redis 127.0.0.1:6380>?slaveof 127.0.0.1 6379?#我們假設(shè)Master和Slave在同一臺(tái)主機(jī),Master的端口為6379
?? ?OK
?? ?上面的方式只是保證了在執(zhí)行slaveof命令之后,redis_6380成為了redis_6379的slave,一旦服務(wù)(redis_6380)重新啟動(dòng)之后,他們之間的復(fù)制關(guān)系將終止。
?? ?如果希望長(zhǎng)期保證這兩個(gè)服務(wù)器之間的Replication關(guān)系,可以在redis_6380的配置文件中做如下修改:
?? ?/>?cd /etc/redis??#切換Redis服務(wù)器配置文件所在的目錄。
?? ?/>?ls
?? ?6379.conf? 6380.conf
?? ?/>?vi 6380.conf
?? ?將
?? ?# slaveof <masterip> <masterport>
?? ?改為
?? ?slaveof 127.0.0.1 6379
?? ?保存退出。
?? ?這樣就可以保證Redis_6380服務(wù)程序在每次啟動(dòng)后都會(huì)主動(dòng)建立與Redis_6379的Replication連接了。
?? ?
四、應(yīng)用示例:

?? ?這里我們假設(shè)Master-Slave已經(jīng)建立。
?? ?#啟動(dòng)master服務(wù)器。
?? ?[root@Stephen-PC redis]#?redis-cli -p 6379
?? ?redis 127.0.0.1:6379>
?? ?#情況Master當(dāng)前數(shù)據(jù)庫(kù)中的所有Keys。
?? ?redis 127.0.0.1:6379>?flushdb
?? ?OK
?? ?#在Master中創(chuàng)建新的Keys作為測(cè)試數(shù)據(jù)。
?? ?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"
?? ?
?? ?#啟動(dòng)slave服務(wù)器。
?? ?[root@Stephen-PC redis]#?redis-cli -p 6380
?? ?#查看Slave中的Keys是否和Master中一致,從結(jié)果看,他們是相等的。
?? ?redis 127.0.0.1:6380>?keys *
?? ?1) "mykey"
?? ?2) "mykey2"
?? ?
?? ?#在Master中刪除其中一個(gè)測(cè)試Key,并查看刪除后的結(jié)果。
?? ?redis 127.0.0.1:6379>?del mykey2
?? ?(integer) 1
?? ?redis 127.0.0.1:6379>?keys *
?? ?1) "mykey"
?? ?
?? ?#在Slave中查看是否mykey2也已經(jīng)在Slave中被刪除。
?? ?redis 127.0.0.1:6380>?keys *
?? ?1) "mykey"

總結(jié)

以上是生活随笔為你收集整理的redis 主从复制 [转]的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。