最近在做零信任安全網(wǎng)關(guān),需要使用Redis作為認證緩存服務(wù)器,因為網(wǎng)關(guān)服務(wù)器分布在多個(gè)集群,每次都跨機房認證不太實(shí)現;所以需要使用Redis主從同步,將過(guò)程記錄下來(lái),希望可以給需要的同學(xué)一點(diǎn)參考。
本篇文章主要是問(wèn)了記錄主從配置的過(guò)程,因此我采用最簡(jiǎn)單的docker方式來(lái)搭建Redis服務(wù),安裝docker的命令如下所示
curl -sSL https://get.daocloud.io/docker | sh
命令執行完成之后,可以看到如下圖所示界面
在上圖中可以看到docker的一些相關(guān)信息,我們要確認docker安裝是否成功還可以使用docker info命令進(jìn)行查看,執行命令如下所示
docker info
命令執行之后,返回信息如下圖所示
在上圖中可以看到docker的版本信息為20.10.3,這是目前的最新版本,已經(jīng)確認安裝成功無(wú)誤。
接下來(lái)我需要使用docker安裝Redis服務(wù),我在實(shí)踐過(guò)程中發(fā)現直接使用Redis鏡像有些異常,于是使用centos鏡像,再在容器里安裝Redis,運行容器的命令如下所示
docker run -d -it -p 16379:6379 --name redis_master centos:7
命令執行完畢之后再進(jìn)入該容器,進(jìn)入容器的命令如下所示
docker exec -it redis_master bash
命令執行完畢后,返回的信息如下圖所示
在上圖中可以看到已經(jīng)成功的進(jìn)入到了容器里面,接下來(lái)我需要在容器里安裝Redis,安裝Redis的命令如下所示
yum install -y epel-release && yum install -y redis
命令執行完畢之后,返回的信息如下圖所示
從上圖中可以看到,Redis已經(jīng)安裝完成,接下來(lái)需要新建一個(gè)Redis的主庫配置文件,執行命令如下所示
vi ~/master.conf
配置文件如下所示,將下列配置文件復制并粘貼到vi編輯窗口當中。
#bind 0.0.0.0 protected-mode yes port 6379 tcp-backlog 511 unixsocket /tmp/redis_auth.sock unixsocketperm 777 timeout 0 tcp-keepalive 300 daemonize yes supervised auto pidfile /var/run/redis_auth.pid loglevel debug logfile /tmp/redis_auth.log databases 16 save "" stop-writes-on-bgsave-error yes rdbcompression yes rdbchecksum yes dbfilename dump.rdb dir /var/lib/redis requirepass 123123123 slave-serve-stale-data yes slave-read-only yes repl-diskless-sync no repl-diskless-sync-delay 5 repl-disable-tcp-nodelay no slave-priority 100 appendonly yes appendfilename "funfe.aof" appendfsync everysec no-appendfsync-on-rewrite no auto-aof-rewrite-percentage 100 auto-aof-rewrite-min-size 512mb aof-load-truncated yes lua-time-limit 5000 slowlog-log-slower-than 10000 slowlog-max-len 128 latency-monitor-threshold 0 notify-keyspace-events "" hash-max-ziplist-entries 512 hash-max-ziplist-value 64 list-max-ziplist-size -2 list-compress-depth 0 set-max-intset-entries 512 zset-max-ziplist-entries 128 zset-max-ziplist-value 64 hll-sparse-max-bytes 3000 activerehashing yes hz 10 aof-rewrite-incremental-fsync yes
在vi編輯窗口粘貼后,如下圖所示
粘貼完成并檢查無(wú)誤之后,使用:wq!命令進(jìn)行保存,接著(zhù)就可以啟動(dòng)Redis程序,啟動(dòng)的命令如下所示
redis-server `/redis.conf
在上方的啟動(dòng)命令中需要指定配置文件路徑,如下圖所示
在上圖中可以看到Redis服務(wù)已經(jīng)啟動(dòng)完成。
接下來(lái)我需要再次啟動(dòng)一個(gè)Redis從庫服務(wù)器,運行容器的命令如下所示
docker run -d -it -p 26379:6379 --name redis_slave centos:7
在上方的命令中,因為在同一臺主機,為了不和主庫端口產(chǎn)生沖突,我將主機端口26379,啟動(dòng)完成之后就可以進(jìn)入從庫容器,運行的命令如下所示
docker exec -it redis_slave bash
命令執行完畢后,同樣需要新建一個(gè)Redis的配置文件,運行的命令如下所示
vi ~/redis.conf
在配置文件中,需要加入從庫的配置代碼,配置樣例如下所示
bind 127.0.0.1 protected-mode yes port 6379 tcp-backlog 511 unixsocket /tmp/redis_auth.sock unixsocketperm 777 timeout 0 tcp-keepalive 300 daemonize yes supervised auto pidfile /var/run/redis_6379.pid loglevel notice logfile /tmp/redis.log databases 16 save "" stop-writes-on-bgsave-error yes rdbcompression yes rdbchecksum yes dbfilename dump.rdb dir /var/lib/redis slaveof 172.23.193.148 16379 masterauth 123123123 slave-serve-stale-data yes slave-read-only yes repl-diskless-sync no repl-diskless-sync-delay 5 repl-disable-tcp-nodelay no slave-priority 100 appendonly yes appendfilename "funfe.aof" appendfsync everysec no-appendfsync-on-rewrite no auto-aof-rewrite-percentage 100 auto-aof-rewrite-min-size 512mb aof-load-truncated yes lua-time-limit 5000 slowlog-log-slower-than 10000 slowlog-max-len 128 latency-monitor-threshold 0 notify-keyspace-events "" hash-max-ziplist-entries 512 hash-max-ziplist-value 64 list-max-ziplist-size -2 list-compress-depth 0 set-max-intset-entries 512 zset-max-ziplist-entries 128 zset-max-ziplist-value 64 hll-sparse-max-bytes 3000 activerehashing yes hz 10 aof-rewrite-incremental-fsync yes
將配置樣例復制進(jìn)來(lái)之后,窗口如下所示
粘貼完成并檢查無(wú)誤之后,使用:wq!命令進(jìn)行保存,接著(zhù)就可以啟動(dòng)Redis程序,啟動(dòng)的命令如下所示
接著(zhù)安裝Redis服務(wù),安裝命令如下所示
yum install -y epel-release && yum install -y redis
命令執行完畢之后,返回的信息如下圖所示
在上圖中可以看到從庫的Redis也安裝完成了,接下來(lái)使用redis-server命令啟動(dòng)從庫服務(wù)器,命令如下圖所示
redis-server redis.conf
命令執行完畢之后,返回的信息如下圖所示
在上圖中可以看到Redis已經(jīng)啟動(dòng)完成,接下來(lái)就可以進(jìn)行驗證效果了
驗證方法主要是在主庫中設置數據,觀(guān)察從庫是否也會(huì )同步更新;
不過(guò)這種操作有點(diǎn)麻煩,我們最好是先檢查一下從庫的啟動(dòng)日志,查看啟動(dòng)日志的命令如下所示
cat /tmp/redis.log
命令執行完畢之后,會(huì )返回Redis的日志信息,如下圖所示
在上圖中的日志信息可以看到從庫已經(jīng)成功將主庫信息復制到本地來(lái)了。
雖然日志中提示成功了,不過(guò)是否成功主從同步還是要以實(shí)際效果為準,這里我回到主服務(wù)器的終端窗口,然后進(jìn)入redis的命令控制臺,進(jìn)入控制臺的命令如下所示
redis-cli -a 123123123
命令執行之后,就可以進(jìn)行redis命令操作了,這里我設置一個(gè)test為123123的鍵值對,設置命令如下所示
set test 123123
命令執行完畢之后,返回的信息如下圖所示
在上圖中可以看到Redis已經(jīng)提示設置鍵值對成功了,接下來(lái)我繼續回到從庫的終端窗口,然后進(jìn)入Redis的控制臺,執行命令如下所示
redis-cli -a 123123123
命令執行完畢之后,就可以通過(guò)keys命令查看當前從庫的鍵值對,命令如下所示
keys *
命令執行完畢之后,返回的信息如下圖所示
在上圖中可以看到test這個(gè)數據已經(jīng)成功復制過(guò)來(lái)了。
到此這篇關(guān)于詳解使用Docker進(jìn)行Redis主從復制實(shí)踐的文章就介紹到這了,更多相關(guān)Docker Redis主從復制內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站