欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > Docker学习笔记4-启动Redis主从同步集群

Docker学习笔记4-启动Redis主从同步集群

2025/4/30 18:05:33 来源:https://blog.csdn.net/weixin_47401101/article/details/147445232  浏览:    关键词:Docker学习笔记4-启动Redis主从同步集群

单节点Redis的并发能力是有上限的,要进一步提高Redis的并发能力,就需要搭建主从集群,实现读写分离。下面通过学习尚硅谷的课程,做一下实现记录。

一、Redis介绍

1、Redis(Remote Dictionary Server)是一个开源的内存数据库,遵守 BSD 协议,它提供了一个高性能的键值(key-value)存储系统,常用于缓存、消息队列、会话存储等应用场景。

2、Redis 的配置文件位于 Redis 安装目录下,文件名为 redis.conf(Windows 名为 redis.windows.conf)。

二、架构设计

1、容器启动

启动两个容器,redis01作为主机master、redis02作为从机slave,从机需要同步主机的数据,主机发生了什么变化,从机可以和主机保持一致,这样可以实现读写分离的效果,所有的写请求交给主机master,所有的读请求交给从机slave。

2、网络配置

将两个容器放到一个网络mynet网络,redis01从外部访问6379端口就是访问6379端口,redis02从外部访问6380端口就是访问6379端口。

3、磁盘挂载

为了实现数据不丢失,把redis01里面保存数据的目录/bitnami/redis/data挂载到外面/app/rd1,把redis02里面保存数据的目录/bitnami/redis/data挂载到外面/app/rd2。

4、redis配置

还要做一些设置,才能保证redis02能同步redis01的数据,设置主机的模式是master,在redis集群中承担主机的作用,还要设置一个密码,这样别人访问 主机需要带密码访问。作为从机,就要告诉它的模式是slave,主机的地址HOST、主机的端口、密码,也可以为从机设置密码。

5、redis镜像选择

使用的redis镜像不是官方镜像,官方镜像做起来会更麻烦,使用的是bitnami的redis镜像。bitnami的镜像,配置起来比较方便,它定义了一些环境变量,直接设置环境变量就可以了,值得推荐。

三、操作步骤

1、创建redis01容器

常见命令:

docker run -d -p 6379:6379 \
> -v /app/rd1:/bitnami/redis/data \
> -e REDIS_REPLICATION_MODE=master \
> -e REDIS_PASSWORD=123456 \
> --network mynet --name redis01 \
> bitnami/redis
2、发现问题

通过命令创建redis01的时候,发现rd1目录权限不够,增加777权限后重新启动容器。

3、重新启动redis01成功

4、创建redis02

A、创建redis02之前,先创建rd2目录,同时增加权限。

B、创建命令

docker run -d -p 6380:6379 \
-v /app/rd2:/bitnami/redis/data \
-e REDIS_REPLICATION_MODE=slave \
-e REDIS_MASTER_HOST=redis01 \
-e REDIS_MASTER_PORT_NUMBER=6379 \
-e REDIS_MASTER_PASSWORD=123456 \
-e REDIS_PASSWORD=123456 \
--network mynet --name redis02 \
bitnami/redis
5、创建成功

四、效果测试

1、使用 redis desktor manager软件,连接2个容器。 

2、在redis01中db0中创建一个key和value,name:zhiyuan,观察在redis02中,会不会同步过来,发现测试通过。

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词