Redis多例項及主從複製環境搭建

dbasdk發表於2018-06-12


一、redis主從複製原理

和MySQL主從複製的原因一樣,Redis雖然讀取寫入的速度都特別快,但是也會產生讀壓力特別大的情況。為了分擔讀壓力,Redis支援主從複製,Redis的主從結構可以採用一主多從或者級聯結構,Redis主從複製可以根據是否是全量分為全量同步和增量同步。下圖為級聯結構:

 

1全量同步

Redis全量複製一般發生在Slave初始化階段,這時Slave需要將Master上的所有資料都複製一份。具體步驟如下: 

1)從伺服器連線主伺服器,傳送SYNC命令; 

2)主伺服器接收到SYNC命名後,開始執行BGSAVE命令生成RDB檔案並使用緩衝區記錄此後執行的所有寫命令; 

3)主伺服器BGSAVE執行完後,向所有從伺服器傳送快照檔案,並在傳送期間繼續記錄被執行的寫命令; 

4)從伺服器收到快照檔案後丟棄所有舊資料,載入收到的快照; 

5)主伺服器快照傳送完畢後開始向從伺服器傳送緩衝區中的寫命令; 

6)從伺服器完成對快照的載入,開始接收命令請求,並執行來自主伺服器緩衝區的寫命令;


 

完成上面幾個步驟後就完成了從伺服器資料初始化的所有操作,從伺服器此時可以接收來自使用者的讀請求。

 

2增量同步

Redis增量複製是指Slave初始化後開始正常工作時主伺服器發生的寫操作同步到從伺服器的過程。 

增量複製的過程主要是主伺服器每執行一個寫命令就會向從伺服器傳送相同的寫命令,從伺服器接收並執行收到的寫命令。

備註:redis2.8之前不支援增量,到2.8之後就支援增量了!

 

3Redis主從同步策略

主從剛剛連線的時候,進行全量同步;全同步結束後,進行增量同步。當然,如果有需要,slave 在任何時候都可以發起全量同步。redis 策略是,無論如何,首先會嘗試進行增量同步,如不成功,要求從機進行全量同步。

 

4注意事項

如果多個Slave斷線了,需要重啟的時候,因為只要Slave啟動,就會傳送sync請求和主機全量同步,當多個同時出現的時候,可能會導致Master IO劇增當機。

 

 

二、Redis單主機多例項部署


前提是之前已經安裝了一個單例項的
redis,redis單例項安裝可參考:CentOS 7.4安裝redis 4.0詳細步驟【http://blog.itpub.net/31015730/viewspace-2155307/】

 

1、複製兩份redis配置檔案

[root@VM_2_13_centos ~]# cp /etc/redis/redis.conf /etc/redis/redis6311.conf  

[root@VM_2_13_centos ~]# cp /etc/redis/redis.conf /etc/redis/redis6322.conf   

[root@VM_2_13_centos ~]#

[root@VM_2_13_centos ~]# ll /etc/redis/

total 192

-rw-r--r-- 1 root root 58976 May 29 20:37 redis6311.conf

-rw-r--r-- 1 root root 58976 May 29 20:37 redis6322.conf

-rw-r--r-- 1 root root 58976 May 29 20:33 redis.conf

 

2、修改配置檔案redis6311.conf和redis6322.conf

[root@VM_2_13_centos ~]# vim  /etc/redis/redis6311.conf

# 監聽埠號,預設為 6379,如果你設為 0 ,redis 將不在 socket 上監聽任何客戶端連線。

port 6311

# 預設情況下 redis 不是作為守護程式執行的,如果你想讓它在後臺執行,你就把它改成 yes。

daemonize yes

# 當redis作為守護程式執行的時候,它會把 pid 預設寫到 /var/run/redis.pid 檔案裡面

# 但是你可以在這裡自己制定它的檔案位置。

pidfile /var/run/redis/redis_6311.pid

# 指定日誌檔案的位置,不同的例項設定不同的日誌檔案,便於問題定位

logfile /var/log/redis/redis_6311.log

# 設定dump的檔名稱,不同的例項設定不同的db檔案,便於問題定位

dbfilename dump_6311.rdb

# 工作目錄 # 例如上面的 dbfilename 只指定了檔名,但是它會寫入到這個目錄下。 # 這個配置項一定是個目錄,而不能是檔名。

# 這個配置項預設值為“./”,最好改相對路徑為絕對路徑

# 如果為相對路徑,redis在哪裡啟動,dump.rdb檔案就會產生在啟動的目錄,這也就是有些人重啟redis後key值消失的原因

dir /var/lib/redis/6311

#配置密碼

requirepass qcloud@2018

 

3、啟動埠為6311的redis

[root@VM_2_13_centos ~]# redis-server /etc/redis/redis6311.conf

[root@VM_2_13_centos ~]#

[root@VM_2_13_centos ~]# ps -ef | grep redis                   

root      6938     1  0 21:14 ?        00:00:00 redis-server 127.0.0.1:6379

root      7001     1  0 21:15 ?        00:00:00 redis-server 127.0.0.1:6311

root      7009  1905  0 21:15 pts/1    00:00:00 grep --color=auto redis

 

4、客戶端登入

[root@VM_2_13_centos ~]# redis-cli -p 6311

127.0.0.1:6311>

127.0.0.1:6311> keys *

(error) NOAUTH Authentication required.

127.0.0.1:6311>

127.0.0.1:6311> auth qcloud@2018

OK

127.0.0.1:6311> keys *

(empty list or set)

 

按照上面的方式配置6322埠的redis,並啟動

[root@VM_2_13_centos ~]# redis-server /etc/redis/redis6322.conf  

[root@VM_2_13_centos ~]# ps -ef | grep redis

root      6938     1  0 21:14 ?        00:00:00 redis-server 127.0.0.1:6379

root      7001     1  0 21:15 ?        00:00:00 redis-server 127.0.0.1:6311

root      7264     1  0 21:20 ?        00:00:00 redis-server 127.0.0.1:6322

root      7279  1905  0 21:20 pts/1    00:00:00 grep --color=auto redis

 

 

三、redis主從環境搭建

 

1、修改6311和6322的配置檔案,主redis為6379埠的redis

[root@VM_2_13_centos ~]# vim /etc/redis/redis6311.conf

slaveof localhost 6379

# masterauth <master-password>

masterauth qcloud@2018

注意:如果主例項配置了密碼,那麼從例項必須配置masterauth,否則同步不成功

 

2、檢視配置是否成功

主庫:

127.0.0.1:6379> info Replication

# Replication

role:master

connected_slaves:2

slave0:ip=127.0.0.1,port=6311,state=online,offset=179,lag=0

slave1:ip=127.0.0.1,port=6322,state=online,offset=179,lag=0

master_replid:d2450e24238b6612630368c6408fd4a9b098da16

master_replid2:0000000000000000000000000000000000000000

master_repl_offset:179

second_repl_offset:-1

repl_backlog_active:1

repl_backlog_size:1048576

repl_backlog_first_byte_offset:1

repl_backlog_histlen:179

 

從庫:

127.0.0.1:6311> info Replication

# Replication

role:slave

master_host:localhost

master_port:6379

master_link_status:up

master_last_io_seconds_ago:7

master_sync_in_progress:0

slave_repl_offset:277

slave_priority:100

slave_read_only:1

connected_slaves:0

master_replid:d2450e24238b6612630368c6408fd4a9b098da16

master_replid2:0000000000000000000000000000000000000000

master_repl_offset:277

second_repl_offset:-1

repl_backlog_active:1

repl_backlog_size:1048576

repl_backlog_first_byte_offset:1

repl_backlog_histlen:277

 

127.0.0.1:6322> info Replication

# Replication

role:slave

master_host:localhost

master_port:6379

master_link_status:up

master_last_io_seconds_ago:1

master_sync_in_progress:0

slave_repl_offset:319

slave_priority:100

slave_read_only:1

connected_slaves:0

master_replid:d2450e24238b6612630368c6408fd4a9b098da16

master_replid2:0000000000000000000000000000000000000000

master_repl_offset:319

second_repl_offset:-1

repl_backlog_active:1

repl_backlog_size:1048576

repl_backlog_first_byte_offset:1

repl_backlog_histlen:319

 

 

3、主從同步測試:

主庫:

127.0.0.1:6379> keys *

1) "name"

127.0.0.1:6379>

127.0.0.1:6379> set age 22

OK

 

從庫:

[root@VM_2_13_centos ~]# redis-cli -p 6311

127.0.0.1:6311> auth qcloud@2018

OK

127.0.0.1:6311> keys *

1) "name"

127.0.0.1:6311> get age

"22"

 

[root@VM_2_13_centos ~]# redis-cli -p 6322

127.0.0.1:6322> auth qcloud@2018

OK

127.0.0.1:6322> keys *

1) "name"

127.0.0.1:6322> get age

"22"


到此為止,redis的主從複製環境搭建完成!


作者:SEian.G(苦練七十二變,笑對八十一難)


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29734436/viewspace-2156053/,如需轉載,請註明出處,否則將追究法律責任。

相關文章