亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

利用docker怎么搭建redis主從

發布時間:2021-01-11 14:12:53 來源:億速云 閱讀:218 作者:Leah 欄目:開發技術

利用docker怎么搭建redis主從?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

 一、構建 Docker 環境

1、創建 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、構建鏡像

docker build -t docker-test .

3、查看當前鏡像

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默認的網絡類型

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

5、創建自定義網絡類型

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

二、搭建 Redis 主從

1、創建 redis-master 容器

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

參數解釋:

-i: 以交互模式運行容器,通常與 -t 同時使用

-t: 為容器重新分配一個偽輸入終端,通常與 -i 同時使用

-d: 后臺運行容器,并返回容器ID;

--name: 為創建的容器命名

--net: 指定網絡模式(這里指定剛才創建的自定義網絡模式)

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

--ip: 為容器制定一個固定的ip

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

2、查看運行中的容器

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

注:查看某個網絡下容器的ip地址

docker network inspect haveyb-network

3、創建 redis-slave1、redis-slave2 容器

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

4、配置 redis-master 容器

(1)進入redis-master 容器

docker exec -it redis-master bash

注:退出容器 `exit`

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

vi /etc/redis.conf

(3)修改參數 bind 127.0.0.1 為 0.0.0.0

bind 0.0.0.0

(4)設置主redis 密碼

requirepass YourPasswordSettings

(5)啟動主redis

redis-server /etc/redis.conf &

(6)redis-cli

redis-cli
auth yourPasswordSettings

5、配置 redis-slave1

(1)進入redis-slave1 容器

docker exec -it redis-slave1 bash

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

vi /etc/redis.conf

(3)修改參數 bind 127.0.0.1 為 0.0.0.0

bind 0.0.0.0

(4)設置 masterauth,添加以下代碼(主redis設置密碼后,從redis連接需要此參數驗權)

masterauth yourPasswordSettings

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

slaveof 172.10.0.2 6379

(5)啟動從redis

redis-server /etc/redis.conf &

(6)redis 客戶端

redis-cli

 6、配置 redis-slave2

同配置 redis-slave1

7、在redis -cli中執行 `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 已經可以獲取了

看完上述內容,你們掌握利用docker怎么搭建redis主從的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

衡水市| 平谷区| 石首市| 镶黄旗| 贺州市| 湘乡市| 黎川县| 杭锦旗| 新田县| 四子王旗| 镇宁| 卫辉市| 准格尔旗| 平果县| 武冈市| 长阳| 江西省| 自贡市| 涟水县| 利川市| 读书| 额尔古纳市| 太白县| 喀喇| 沧州市| 兴和县| 大城县| 麦盖提县| 青田县| 浮山县| 城固县| 青河县| 清徐县| 驻马店市| 商城县| 阿拉善左旗| 瓦房店市| 萨迦县| 通许县| 榆社县| 惠东县|