中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用Docker怎么實現Redis主從復制

發布時間:2021-04-13 15:37:34 來源:億速云 閱讀:229 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關使用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.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編輯窗口粘貼后,如下圖所示

使用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.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

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

使用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主從復制

看完上述內容,你們對使用Docker怎么實現Redis主從復制有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

陕西省| 清镇市| 高青县| 稻城县| 汨罗市| 海阳市| 石景山区| 资中县| 蓝山县| 天峨县| 常熟市| 岑巩县| 榆社县| 疏附县| 石阡县| 嘉鱼县| 小金县| 金坛市| 新乡市| 长宁县| 太谷县| 榆林市| 西青区| 长乐市| 潍坊市| 柳林县| 乌拉特前旗| 克山县| 五峰| 琼海市| 柳江县| 上饶市| 兴隆县| 靖边县| 额尔古纳市| 突泉县| 禄丰县| 大安市| 吴旗县| 莱州市| 白朗县|