目錄一、背景
我們提供的服務(wù)有:成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、吳江ssl等。為上千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的吳江網(wǎng)站制作公司
最近在做零信任安全網(wǎng)關(guān),需要使用Redis作為認(rèn)證緩存服務(wù)器,因?yàn)榫W(wǎng)關(guān)服務(wù)器分布在多個(gè)集群,每次都跨機(jī)房認(rèn)證不太實(shí)現(xiàn);所以需要使用Redis主從同步,將過程記錄下來,希望可以給需要的同學(xué)一點(diǎn)參考。二、操作步驟 安裝Docker 主服務(wù)配置 從服務(wù)配置 驗(yàn)證同步效果三、安裝Docker
curl -sSL https://get.daocloud.io/docker | sh
命令執(zhí)行完成之后,可以看到如下圖所示界面
docker info
命令執(zhí)行之后,返回信息如下圖所示
四、主服務(wù)配置
docker run -d -it -p 16379:6379 --name redis_master centos:7
docker exec -it redis_master bash
命令執(zhí)行完畢后,返回的信息如下圖所示
yum install -y epel-release && yum install -y redis
命令執(zhí)行完畢之后,返回的信息如下圖所示
vi ~/master.conf
#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編輯窗口粘貼后,如下圖所示
redis-server `/redis.conf
在上方的啟動(dòng)命令中需要指定配置文件路徑,如下圖所示
五、從服務(wù)配置
docker run -d -it -p 26379:6379 --name redis_slave centos:7
docker exec -it redis_slave bash
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
將配置樣例復(fù)制進(jìn)來之后,窗口如下所示
粘貼完成并檢查無誤之后,使用:wq!命令進(jìn)行保存,接著就可以啟動(dòng)Redis程序,啟動(dòng)的命令如下所示
yum install -y epel-release && yum install -y redis
命令執(zhí)行完畢之后,返回的信息如下圖所示
redis-server redis.conf
命令執(zhí)行完畢之后,返回的信息如下圖所示
六、結(jié)果驗(yàn)證
6.1 初步驗(yàn)證
cat /tmp/redis.log
命令執(zhí)行完畢之后,會(huì)返回Redis的日志信息,如下圖所示
6.2 同步檢查
redis-cli -a 123123123
set test 123123
命令執(zhí)行完畢之后,返回的信息如下圖所示
redis-cli -a 123123123
命令執(zhí)行完畢之后,就可以通過keys命令查看當(dāng)前從庫的鍵值對(duì),命令如下所示
keys *
命令執(zhí)行完畢之后,返回的信息如下圖所示
在上圖中可以看到test這個(gè)數(shù)據(jù)已經(jīng)成功復(fù)制過來了。
到此這篇關(guān)于詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐的文章就介紹到這了,更多相關(guān)Docker Redis主從復(fù)制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!