您好,登錄后才能下訂單哦!
一、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之后就支持增量了!
3、Redis主從同步策略
主從剛剛連接的時候,進行全量同步;全同步結束后,進行增量同步。當然,如果有需要,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"
作者:SEian.G(苦練七十二變,笑對八十一難)
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。