日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

使用docker搭建redis主从

發(fā)布時(shí)間:2023/12/4 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用docker搭建redis主从 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?一、構(gòu)建 Docker 環(huán)境

1、創(chuàng)建 dockerfile

FROM centos:latest RUN groupadd -r redis && useradd ?-r -g redis redis RUN yum -y update && ?yum -y install epel-release && yum -y install redis && yum -y install net-tools EXPOSE 6379

 
2、構(gòu)建鏡像

docker build -t docker-test .

 
3、查看當(dāng)前鏡像

docker iamges REPOSITORY ? ?TAG ? ? ? ? IMAGE ID ? ? ? ?CREATED ? ? ? ? ? ? SIZE docker-test ? latest ? ? ?ccebd30e466a ? ?12 minutes ago ? ? ?396MB centos ? ? ? ?latest ? ? ?470671670cac ? ?7 weeks ago ? ? ? ? 237MB

 
4、查看docker默認(rèn)的網(wǎng)絡(luò)類型

docker network ls NETWORK ID ? ? ? ? ?NAME ? ? ? ? ? ? ? ?DRIVER ? ? ? ? ? ? ?SCOPE a43e79987e98 ? ? ? ?bridge ? ? ? ? ? ? ?bridge ? ? ? ? ? ? ?local 6b73067403dc ? ? ? ?host ? ? ? ? ? ? ? ?host ? ? ? ? ? ? ? ?local b8ad4981e57e ? ? ? ?none ? ? ? ? ? ? ? ?null ? ? ? ? ? ? ? ?local

 
5、創(chuàng)建自定義網(wǎng)絡(luò)類型

docker network create ?--subnet=172.10.0.0/16 ?haveyb-network


 
二、搭建 Redis 主從

1、創(chuàng)建 redis-master 容器

docker run -itd --name ?redis-master ?--net haveyb-network ?-p 6380:6379 ?--ip 172.10.0.2 ?docker-test


參數(shù)解釋:

-i:?以交互模式運(yùn)行容器,通常與 -t 同時(shí)使用

-t:?為容器重新分配一個(gè)偽輸入終端,通常與 -i 同時(shí)使用

-d:?后臺(tái)運(yùn)行容器,并返回容器ID;

--name: 為創(chuàng)建的容器命名

--net: 指定網(wǎng)絡(luò)模式(這里指定剛才創(chuàng)建的自定義網(wǎng)絡(luò)模式)

-p:?端口映射,格式為:主機(jī)(宿主)端口:容器端口

--ip: 為容器制定一個(gè)固定的ip

后面再指定一下使用的鏡像(這里使用的就是剛才創(chuàng)建的鏡像 docker-test)


 
2、查看運(yùn)行中的容器

docker ps -a CONTAINER ID ??? ? IMAGE ? ? ? ? ?COMMAND ? ? ?? ??? ?CREATED dc9344bbd25f ? ? docker-test ?? ?"/bin/bash" ?? ??? ? 2 minutes agoSTATUS ??? ??? ? PORTS?? ??? ? ?? ??? ??? ??? ?NAMES Up 2 minutes ? ? 0.0.0.0:6380->6379/tcp?? ??? ?redis-master

注:查看某個(gè)網(wǎng)絡(luò)下容器的ip地址

docker network inspect haveyb-network


 
3、創(chuàng)建 redis-slave1、redis-slave2 容器

docker run -itd --name ?redis-slave1 ?--net haveyb-network ?-p 6381:6379 ?--ip 172.10.0.3 ?docker-testdocker run -itd --name ?redis-slave2 ?--net haveyb-network ?-p 6382:6379 ?--ip 172.10.0.4 ?docker-test

 
4、配置 redis-master 容器

(1)進(jìn)入redis-master 容器

docker exec -it redis-master bash


注:退出容器 `exit`

?

(2)修改redis.conf 配置文件

vi /etc/redis.conf


(3)修改參數(shù) bind 127.0.0.1 為 0.0.0.0

bind 0.0.0.0

(4)設(shè)置主redis 密碼

requirepass YourPasswordSettings


(5)啟動(dòng)主redis

redis-server /etc/redis.conf &

(6)redis-cli

redis-cli auth yourPasswordSettings

 
5、配置 redis-slave1

(1)進(jìn)入redis-slave1 容器

docker exec -it redis-slave1 bash

(2)修改redis.conf 配置文件

vi /etc/redis.conf


(3)修改參數(shù) bind 127.0.0.1 為 0.0.0.0

bind 0.0.0.0

(4)設(shè)置 masterauth,添加以下代碼(主redis設(shè)置密碼后,從redis連接需要此參數(shù)驗(yàn)權(quán))

masterauth yourPasswordSettings

(5)設(shè)置 slaveof (設(shè)置主 redis 的 ip 和 port)

slaveof 172.10.0.2 6379

(5)啟動(dòng)從redis

redis-server /etc/redis.conf &

(6)redis 客戶端

redis-cli

 
?6、配置 redis-slave2

同配置 redis-slave1

 
7、在redis -cli中執(zhí)行 `info replication` 可以查看主從信息

?redis-master

127.0.0.1:6379> info replication # Replication role:master connected_slaves:2 slave0:ip=172.10.0.3,port=6379,state=online,offset=3105,lag=1 slave1:ip=172.10.0.4,port=6379,state=online,offset=3105,lag=1 master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1 master_replid2:0000000000000000000000000000000000000000 master_repl_offset:3105 second_repl_offset:-1 repl_backlog_active:1 repl_backlog_size:1048576 repl_backlog_first_byte_offset:1 repl_backlog_histlen:3105 127.0.0.1:6379>?

redis-slave1

127.0.0.1:6379> info replication? # Replication role:slave master_host:172.10.0.2 master_port:6379 master_link_status:up master_last_io_seconds_ago:1 master_sync_in_progress:0 slave_repl_offset:3203 slave_priority:100 slave_read_only:1 connected_slaves:0 master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1 master_replid2:0000000000000000000000000000000000000000 master_repl_offset:3203 second_repl_offset:-1 repl_backlog_active:1 repl_backlog_size:1048576 repl_backlog_first_byte_offset:1 repl_backlog_histlen:3203 127.0.0.1:6379>?

 
8、在 redis-master 中寫入key,redis-slave1 和 redis-slave2 已經(jīng)可以獲取了

 

 
?

總結(jié)

以上是生活随笔為你收集整理的使用docker搭建redis主从的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。