使用docker搭建redis主从的方法步骤
作者:m_nanle_xiaobudiu 发布时间:2023-05-02 13:15:45
一、构建 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 已经可以获取了
来源:https://blog.csdn.net/m_nanle_xiaobudiu/article/details/104814617


猜你喜欢
- 10月10日,巨人网络《万王之王3》团队今日宣布,该公司自主研发的魔幻题材3D MMORPG《万王之王3》将于本月15日启动不删档封测。这意
- 你可能有时需要在 Linux 上创建或者删除符号链接。如果有,你知道该怎样做吗?之前你做过吗?你踩坑没有?如果你踩过坑,那没什么问题。如果还
- 今天带大家了解一下ext4的历史,包括其与ext3和之前的其它文件系统之间的区别大多数现代Linux发行版默认为ext 4文件系统,就像以前
- IDC里的一台服务器的/分区使用率爆满了!已达到100%!经查看发现有个文件过大(80G),于是在跟有关同事确认后rm -f果断删除该文件。
- 现在全国都在清理整顿CN域名,新网互联就发出了“关于落实对已注册cn域名开展实名制清查的紧急通知”,昨天提供了上传域名资料的方法,聚友在这边
- 近来群里经常有朋友问我做站的经验,每次都大概重复着同样的话题,其实做站没有什么经验,做站就和做人一样,厚道做人,老实做站,这就是我最深刻的体
- 目前常用的文档格式有TXT、WORD、PDF等,对这些文档的搜索引擎优化方法比较简单,只要在文件标题和文档首页前面的一些文字信息中包含关键词
- 很多站长认为做方向链接是一个很简单的事情,其实做方向链接也是有一定的原则的.seo其实就是从一点一滴多起的,当很多小处改变了之后,就形成了一
- 前言在使用docker部署redis的时候,遇到很多坑,在此记录下遇到的问题一、安装docker和docker-compose### 安装d
- 很多企业局域网内都架设了邮件服务器,用于进行公文发送和工作交流。但使用专业的企业邮件系统软件需要大量的资金投入,这对于很多企业来说是无法承受
- 现在很多的朋友都用SERV-U做个人FTP的服务器,有关如何使用SERV-U架设服务器的文章很多了,这儿我就不多说了。不过大家不知道注意到了
- 一、VMware vSphere简介VMware vSphere 是业界领先且最可靠的虚拟化平台。vSphere将应用程序和操作系统从底层硬
- 任何一个事情都有重点,我在‘论坛营销成功学(一)’中就把论坛营销的重点基本都说出来了。看过以后你可能觉得这些东西都知道,没有必要往下看了。其
- 一、环境在虚拟机上运行的ubuntu16.04 , 使用命令uname -r查看当前系统内核版本当前版本为4.15.0-45-generic
- 本文介绍了Visual Studio Code(vscode) git的使用,分享给大家,具体如下:1.创建一个github账号  
- Linux 中ip forward功能是一个比较方便实用的功能,只需要简单配置,添加几条路由,即可实现ip转发。本文基于CentOS 7下采
- asp之家注:呵呵,我也发现了,已经好几天没开QQ了,今天一开发现了这个异常,我还疑问电脑中了什么病毒了,怎么都变成手机在线状态了?吓了我一
- 前言Cut 输入字符中指定的字段或指定的范围。若处理的是字段,则定界符隔开的即为各字段,而输出时字段也以给定的定界符隔开。默认的定界符为制表
- 这几条都是在管理中心学来的,可能有些朋友没有注意。1、杜绝内容复制,就是说多地址指向同一内容,收录太多重复内容,浪费存储资源,所以大多搜索引
- 一、apache、php、mysql安装1.安装php分步式安装:下载php:wget http://cn2.php.NET/get/php