redis主从配置+集群搭建

简介: redis主从配置+集群搭建

为什么需要主从配置?????

当出现高并发流量情况 如果我们只有一个redis服务器  挂掉之后  网站的运营会出现问题.

我们可以多弄几台redis服务器,使得一台服务器挂掉自动切换到另一台redis服务器,这个时候就实现了一个高可用的系统

主从配置 环境是2台 ubuntu server 18.04  虚拟机

首先安装redis-server

sudo apt-get update  
sudo apt-get install redis-server
  • 主库配置. 修改配置文件
vim /etc/redis/redis.conf
# bind 127.0.0.1 ::1   注释掉这个外链地址 允许外部连接麻   不然从库怎么去连接呢  对吧
  • 从库配置(也需要安装redis)也就是另一台服务器
修改配置文件
vim /etc/redis/redis.conf
# slaveof 主库ip 主库端口号  把这行注释打开  
配置完成都需要去重启服务
  • 主库查看

配置完成之后就需要去查看是否配置成功了,然后去主库服务器上使用redis-cli 连接


输入 info命令查看

有一个 Replication

connected_slaves:1   为一就说明有了一个重库   好吧 因为比较简单 所以不做详细说明

手动搭建redis集群

  • 集群搭建一般需要的服务器比较多   redis最少需要6台   3主3从  我如果开这么多虚拟机我电脑可能炸掉 所以我直接在一台虚拟机上面搭建6个redis
  • 使用不同的端口号  redis版本使用的是4.0
  • 安装redis

在官网找到redis的包   使用wget获取资源 然后解压 因为官方提供了makefile 所以比较方便  直接make就可以了 编译好的会出现在src目录里面

  • 如果是一台新的机器 可能一些依赖都是需要我们自己手动去安装  apt-get install gcc g++ make 对吧  随后就可以为所欲为

为了方便  我直接把我们需要用到的一些东西直接拷贝到了我的家目录

cp ./src/redis-server /home/test/redis-cluster/
cp ./src/redis-cli /home/test/redis-cluster/
cp ./src/redis-trib.rb /home/test/redis-cluster/

拷贝过去后  然后我去redis-cluster里面创建6个文件夹  每个存放一个redis服务

mkdir 7000 7001 7002 7003 7004 7005

给每一个文件夹都设置他们的配置文件

redis.conf (内容如下)
port 7000  这是端口                  //你希望是啥就是啥
cluster-enabled yes                 //开启集群模式
cluster-config-file nodes.conf      //集群的配置  配置文件首次启动自动生成 
cluster-node-timeout 5000           //请求超时
appendonly yes                      //aof日志开启  有需要就开启,它会每次写操作都记录一条日志
  • 然后分别去每个目录下启动每个服务

../redis-server ./redis.conf   这样启动会发现  如果我们将终端关闭  这个redis也就关闭 所以我们使用nohub命令去后台运行

nohup ../redis-server ./redis.conf &   启动完6个redis

  • 随后我们需要创建集群

使用redis-trib.rb 来创建

因为是ruby编写的   所以需要先安装一个redis   顺便安装一个rubyredis    gem install redis

  • 使用命令

./redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005

这里使用的命令是create,因为我们要创建一个新的集群。该选项--cluster-replicas 1意味着我们希望每个创建的主服务器都有一个从服 其他参数是我要用于创建新集群的实例的地址列表。

显然,我们要求的唯一设置是创建一个包含3个主服务器和3个从服务器的集群。

Redis-cli将为您提供配置。键入yes接受建议的配置。将配置并加入群集,这意味着实例将被引导为彼此通信。最后,如果一切顺利,你会看到这样的消息:

[OK] All 16384 slots covered  这意味着至少有一个主实例为16384个可用插槽提供服务。

然后使用 redis-cli -c -p 7000  连接redis  (-c 代表集群模式)

set name test

然后切换别的redis服务  去get 获取成功

本文为作者原创,手码不易,允许转载,转载后请以链接形式说明文章出处。

目录
相关文章
|
8月前
|
存储 负载均衡 NoSQL
【赵渝强老师】Redis Cluster分布式集群
Redis Cluster是Redis的分布式存储解决方案,通过哈希槽(slot)实现数据分片,支持水平扩展,具备高可用性和负载均衡能力,适用于大规模数据场景。
535 2
|
6月前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。
647 25
|
12月前
|
存储 NoSQL 数据库
Redis 逻辑数据库与集群模式详解
Redis 是高性能内存键值数据库,广泛用于缓存与实时数据处理。本文深入解析 Redis 逻辑数据库与集群模式:逻辑数据库提供16个独立存储空间,适合小规模隔离;集群模式通过分布式架构支持高并发和大数据量,但仅支持 database 0。文章对比两者特性,讲解配置与实践注意事项,并探讨持久化及性能优化策略,助你根据需求选择最佳方案。
617 5
|
6月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
722 6
|
7月前
|
存储 监控 NoSQL
Redis高可用架构全解析:从主从复制到集群方案
Redis高可用确保服务持续稳定,避免单点故障导致数据丢失或业务中断。通过主从复制实现数据冗余,哨兵模式支持自动故障转移,Cluster集群则提供分布式数据分片与水平扩展,三者层层递进,保障读写分离、容灾切换与大规模数据存储,构建高性能、高可靠的Redis架构体系。
|
9月前
|
负载均衡 NoSQL Redis
【赵渝强老师】Redis的主从复制集群
Redis主从复制是指将一台Redis服务器的数据复制到其他Redis服务器,实现数据热备份、故障恢复、负载均衡及高可用架构的基础。主节点负责写操作,从节点同步数据并可提供读服务,提升并发处理能力。
261 5
|
9月前
|
NoSQL 安全 Linux
设置Redis在CentOS7上的自启动配置
这些步骤总结了在CentOS 7系统上设置Redis服务自启动的过程。这些命令提供了一个直接且明了的方式,确保Redis作为关键组件在系统启动时能自动运行,保障了依赖于Redis服务的应用的稳定性和可用性。
685 9
|
8月前
|
存储 NoSQL 算法
Redis的集群架构与使用经验
本文介绍了Redis的集群架构与使用经验,包括主从复制、哨兵集群及Cluster分片集群的应用场景与实现原理。内容涵盖Redis主从同步机制、数据分片存储方式、事务支持及与Memcached的区别,并讨论了Redis内存用尽时的处理策略。适用于了解Redis高可用与性能优化方案。
|
NoSQL Redis
[Redis]Redis指南二 配置
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/73863746 我们可以...
1035 0
|
11月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?