国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

詳解使用Docker進行Redis主從復制實踐

瀏覽:24日期:2024-10-28 17:16:01
一、背景

最近在做零信任安全網關,需要使用Redis作為認證緩存服務器,因為網關服務器分布在多個集群,每次都跨機房認證不太實現;所以需要使用Redis主從同步,將過程記錄下來,希望可以給需要的同學一點參考。

二、操作步驟 安裝Docker 主服務配置 從服務配置 驗證同步效果三、安裝Docker

本篇文章主要是問了記錄主從配置的過程,因此我采用最簡單的docker方式來搭建Redis服務,安裝docker的命令如下所示

curl -sSL https://get.daocloud.io/docker | sh

命令執行完成之后,可以看到如下圖所示界面

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到docker的一些相關信息,我們要確認docker安裝是否成功還可以使用docker info命令進行查看,執行命令如下所示

docker info

命令執行之后,返回信息如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到docker的版本信息為20.10.3,這是目前的最新版本,已經確認安裝成功無誤。

四、主服務配置

接下來我需要使用docker安裝Redis服務,我在實踐過程中發現直接使用Redis鏡像有些異常,于是使用centos鏡像,再在容器里安裝Redis,運行容器的命令如下所示

docker run -d -it -p 16379:6379 --name redis_master centos:7

命令執行完畢之后再進入該容器,進入容器的命令如下所示

docker exec -it redis_master bash

命令執行完畢后,返回的信息如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到已經成功的進入到了容器里面,接下來我需要在容器里安裝Redis,安裝Redis的命令如下所示

yum install -y epel-release && yum install -y redis

命令執行完畢之后,返回的信息如下圖所示

詳解使用Docker進行Redis主從復制實踐

從上圖中可以看到,Redis已經安裝完成,接下來需要新建一個Redis的主庫配置文件,執行命令如下所示

vi ~/master.conf

配置文件如下所示,將下列配置文件復制并粘貼到vi編輯窗口當中。

#bind 0.0.0.0protected-mode yesport 6379tcp-backlog 511unixsocket /tmp/redis_auth.sockunixsocketperm 777timeout 0tcp-keepalive 300daemonize yessupervised autopidfile /var/run/redis_auth.pidloglevel debuglogfile /tmp/redis_auth.logdatabases 16save ''stop-writes-on-bgsave-error yesrdbcompression yesrdbchecksum yesdbfilename dump.rdbdir /var/lib/redisrequirepass 123123123slave-serve-stale-data yesslave-read-only yesrepl-diskless-sync norepl-diskless-sync-delay 5repl-disable-tcp-nodelay noslave-priority 100appendonly yesappendfilename 'funfe.aof'appendfsync everysecno-appendfsync-on-rewrite noauto-aof-rewrite-percentage 100auto-aof-rewrite-min-size 512mbaof-load-truncated yeslua-time-limit 5000slowlog-log-slower-than 10000slowlog-max-len 128latency-monitor-threshold 0notify-keyspace-events ''hash-max-ziplist-entries 512hash-max-ziplist-value 64list-max-ziplist-size -2list-compress-depth 0set-max-intset-entries 512zset-max-ziplist-entries 128zset-max-ziplist-value 64hll-sparse-max-bytes 3000activerehashing yeshz 10aof-rewrite-incremental-fsync yes

在vi編輯窗口粘貼后,如下圖所示

詳解使用Docker進行Redis主從復制實踐

粘貼完成并檢查無誤之后,使用:wq!命令進行保存,接著就可以啟動Redis程序,啟動的命令如下所示

redis-server `/redis.conf

在上方的啟動命令中需要指定配置文件路徑,如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到Redis服務已經啟動完成。

五、從服務配置

接下來我需要再次啟動一個Redis從庫服務器,運行容器的命令如下所示

docker run -d -it -p 26379:6379 --name redis_slave centos:7

在上方的命令中,因為在同一臺主機,為了不和主庫端口產生沖突,我將主機端口26379,啟動完成之后就可以進入從庫容器,運行的命令如下所示

docker exec -it redis_slave bash

命令執行完畢后,同樣需要新建一個Redis的配置文件,運行的命令如下所示

vi ~/redis.conf

在配置文件中,需要加入從庫的配置代碼,配置樣例如下所示

bind 127.0.0.1protected-mode yesport 6379tcp-backlog 511unixsocket /tmp/redis_auth.sockunixsocketperm 777timeout 0tcp-keepalive 300daemonize yessupervised autopidfile /var/run/redis_6379.pidloglevel noticelogfile /tmp/redis.logdatabases 16save ''stop-writes-on-bgsave-error yesrdbcompression yesrdbchecksum yesdbfilename dump.rdbdir /var/lib/redisslaveof 172.23.193.148 16379masterauth 123123123slave-serve-stale-data yesslave-read-only yesrepl-diskless-sync norepl-diskless-sync-delay 5repl-disable-tcp-nodelay noslave-priority 100appendonly yesappendfilename 'funfe.aof'appendfsync everysecno-appendfsync-on-rewrite noauto-aof-rewrite-percentage 100auto-aof-rewrite-min-size 512mbaof-load-truncated yeslua-time-limit 5000slowlog-log-slower-than 10000slowlog-max-len 128latency-monitor-threshold 0notify-keyspace-events ''hash-max-ziplist-entries 512hash-max-ziplist-value 64list-max-ziplist-size -2list-compress-depth 0set-max-intset-entries 512zset-max-ziplist-entries 128zset-max-ziplist-value 64hll-sparse-max-bytes 3000activerehashing yeshz 10aof-rewrite-incremental-fsync yes

將配置樣例復制進來之后,窗口如下所示

詳解使用Docker進行Redis主從復制實踐

粘貼完成并檢查無誤之后,使用:wq!命令進行保存,接著就可以啟動Redis程序,啟動的命令如下所示接著安裝Redis服務,安裝命令如下所示

yum install -y epel-release && yum install -y redis

命令執行完畢之后,返回的信息如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到從庫的Redis也安裝完成了,接下來使用redis-server命令啟動從庫服務器,命令如下圖所示

redis-server redis.conf

命令執行完畢之后,返回的信息如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到Redis已經啟動完成,接下來就可以進行驗證效果了

六、結果驗證

驗證方法主要是在主庫中設置數據,觀察從庫是否也會同步更新;

6.1 初步驗證

不過這種操作有點麻煩,我們最好是先檢查一下從庫的啟動日志,查看啟動日志的命令如下所示

cat /tmp/redis.log

命令執行完畢之后,會返回Redis的日志信息,如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中的日志信息可以看到從庫已經成功將主庫信息復制到本地來了。

6.2 同步檢查

雖然日志中提示成功了,不過是否成功主從同步還是要以實際效果為準,這里我回到主服務器的終端窗口,然后進入redis的命令控制臺,進入控制臺的命令如下所示

redis-cli -a 123123123

命令執行之后,就可以進行redis命令操作了,這里我設置一個test為123123的鍵值對,設置命令如下所示

set test 123123

命令執行完畢之后,返回的信息如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到Redis已經提示設置鍵值對成功了,接下來我繼續回到從庫的終端窗口,然后進入Redis的控制臺,執行命令如下所示

redis-cli -a 123123123

命令執行完畢之后,就可以通過keys命令查看當前從庫的鍵值對,命令如下所示keys *

命令執行完畢之后,返回的信息如下圖所示

詳解使用Docker進行Redis主從復制實踐

在上圖中可以看到test這個數據已經成功復制過來了。

到此這篇關于詳解使用Docker進行Redis主從復制實踐的文章就介紹到這了,更多相關Docker Redis主從復制內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Docker
相關文章:
主站蜘蛛池模板: 韩国一级毛片 | 手机看片日韩国产 | 男人一进一出桶女人视频 | 性欧美成人依依影院 | 日本b站一卡二卡乱码入口 日本s色大片在线观看 | 国产成人夜间影院在线观看 | 一级片视频在线 | 精品国产品国语在线不卡丶 | 黄色三级视频 | 精品一区二区三区免费毛片爱 | 91理论片午午伦夜理片久久 | 国产成人免费片在线观看 | 日韩欧美视频一区 | 爽爽窝窝午夜精品一区二区 | 男女性关系视频免费观看软件 | 国产一区二区免费在线 | 免费在线亚洲 | 中文字幕亚洲综合久久男男 | 国产人成精品 | 欧美jizzhd精品欧美 | 国产成人精品久久 | 国产后式a一视频 | 国产成人精品区在线观看 | 国产成在线观看免费视频成本人 | 国产精品日韩专区 | 欧美亚洲一区二区三区在线 | 欧美巨大video粗暴 | 99久久综合狠狠综合久久一区 | 粉嫩高中生的第一次在线观看 | 国产美女做爰免费视频软件 | 小草青青神马影院 | 久久夜色精品国产噜噜亚洲a | 欧美jlzz18性欧美 | 国产成人免费高清激情视频 | 免费一级片视频 | 一级做a| 日本三片在在线播放 | 国产三级麻豆 | 亚洲性免费 | 91原创在线 | 日本视频播放免费线上观看 |