国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

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

最近在做零信任安全網(wǎng)關(guān),需要使用Redis作為認(rèn)證緩存服務(wù)器,因?yàn)榫W(wǎng)關(guān)服務(wù)器分布在多個(gè)集群,每次都跨機(jī)房認(rèn)證不太實(shí)現(xiàn);所以需要使用Redis主從同步,將過(guò)程記錄下來(lái),希望可以給需要的同學(xué)一點(diǎn)參考。

二、操作步驟 安裝Docker 主服務(wù)配置 從服務(wù)配置 驗(yàn)證同步效果三、安裝Docker

本篇文章主要是問(wèn)了記錄主從配置的過(guò)程,因此我采用最簡(jiǎn)單的docker方式來(lái)搭建Redis服務(wù),安裝docker的命令如下所示

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

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到docker的一些相關(guān)信息,我們要確認(rèn)docker安裝是否成功還可以使用docker info命令進(jìn)行查看,執(zhí)行命令如下所示

docker info

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到docker的版本信息為20.10.3,這是目前的最新版本,已經(jīng)確認(rèn)安裝成功無(wú)誤。

四、主服務(wù)配置

接下來(lái)我需要使用docker安裝Redis服務(wù),我在實(shí)踐過(guò)程中發(fā)現(xiàn)直接使用Redis鏡像有些異常,于是使用centos鏡像,再在容器里安裝Redis,運(yùn)行容器的命令如下所示

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

命令執(zhí)行完畢之后再進(jìn)入該容器,進(jìn)入容器的命令如下所示

docker exec -it redis_master bash

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到已經(jīng)成功的進(jìn)入到了容器里面,接下來(lái)我需要在容器里安裝Redis,安裝Redis的命令如下所示

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

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

從上圖中可以看到,Redis已經(jīng)安裝完成,接下來(lái)需要新建一個(gè)Redis的主庫(kù)配置文件,執(zhí)行命令如下所示

vi ~/master.conf

配置文件如下所示,將下列配置文件復(fù)制并粘貼到vi編輯窗口當(dāng)中。

#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進(jìn)行Redis主從復(fù)制實(shí)踐

粘貼完成并檢查無(wú)誤之后,使用:wq!命令進(jìn)行保存,接著就可以啟動(dòng)Redis程序,啟動(dòng)的命令如下所示

redis-server `/redis.conf

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到Redis服務(wù)已經(jīng)啟動(dòng)完成。

五、從服務(wù)配置

接下來(lái)我需要再次啟動(dòng)一個(gè)Redis從庫(kù)服務(wù)器,運(yùn)行容器的命令如下所示

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

在上方的命令中,因?yàn)樵谕慌_(tái)主機(jī),為了不和主庫(kù)端口產(chǎn)生沖突,我將主機(jī)端口26379,啟動(dòng)完成之后就可以進(jìn)入從庫(kù)容器,運(yùn)行的命令如下所示

docker exec -it redis_slave bash

命令執(zhí)行完畢后,同樣需要新建一個(gè)Redis的配置文件,運(yùn)行的命令如下所示

vi ~/redis.conf

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

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

將配置樣例復(fù)制進(jìn)來(lái)之后,窗口如下所示

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

粘貼完成并檢查無(wú)誤之后,使用:wq!命令進(jìn)行保存,接著就可以啟動(dòng)Redis程序,啟動(dòng)的命令如下所示接著安裝Redis服務(wù),安裝命令如下所示

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

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到從庫(kù)的Redis也安裝完成了,接下來(lái)使用redis-server命令啟動(dòng)從庫(kù)服務(wù)器,命令如下圖所示

redis-server redis.conf

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到Redis已經(jīng)啟動(dòng)完成,接下來(lái)就可以進(jìn)行驗(yàn)證效果了

六、結(jié)果驗(yàn)證

驗(yàn)證方法主要是在主庫(kù)中設(shè)置數(shù)據(jù),觀察從庫(kù)是否也會(huì)同步更新;

6.1 初步驗(yàn)證

不過(guò)這種操作有點(diǎn)麻煩,我們最好是先檢查一下從庫(kù)的啟動(dòng)日志,查看啟動(dòng)日志的命令如下所示

cat /tmp/redis.log

命令執(zhí)行完畢之后,會(huì)返回Redis的日志信息,如下圖所示

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中的日志信息可以看到從庫(kù)已經(jīng)成功將主庫(kù)信息復(fù)制到本地來(lái)了。

6.2 同步檢查

雖然日志中提示成功了,不過(guò)是否成功主從同步還是要以實(shí)際效果為準(zhǔn),這里我回到主服務(wù)器的終端窗口,然后進(jìn)入redis的命令控制臺(tái),進(jìn)入控制臺(tái)的命令如下所示

redis-cli -a 123123123

命令執(zhí)行之后,就可以進(jìn)行redis命令操作了,這里我設(shè)置一個(gè)test為123123的鍵值對(duì),設(shè)置命令如下所示

set test 123123

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到Redis已經(jīng)提示設(shè)置鍵值對(duì)成功了,接下來(lái)我繼續(xù)回到從庫(kù)的終端窗口,然后進(jìn)入Redis的控制臺(tái),執(zhí)行命令如下所示

redis-cli -a 123123123

命令執(zhí)行完畢之后,就可以通過(guò)keys命令查看當(dāng)前從庫(kù)的鍵值對(duì),命令如下所示keys *

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

詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

在上圖中可以看到test這個(gè)數(shù)據(jù)已經(jīng)成功復(fù)制過(guò)來(lái)了。

到此這篇關(guān)于詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐的文章就介紹到這了,更多相關(guān)Docker Redis主從復(fù)制內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Docker
相關(guān)文章:
主站蜘蛛池模板: 太保市| 长武县| 浦县| 上林县| 阆中市| 仪陇县| 佛坪县| 固镇县| 奎屯市| 嘉义县| 章丘市| 木里| 客服| 黑水县| 乌审旗| 双江| 南靖县| 昌吉市| 呼伦贝尔市| 上虞市| 临沧市| 瑞丽市| 库车县| 阿拉尔市| 类乌齐县| 拜泉县| 连云港市| 山西省| 乐清市| 张掖市| 通渭县| 淮南市| 合阳县| 柳河县| 华池县| 佛坪县| 宁夏| 咸宁市| 石屏县| 南木林县| 黄龙县|