Redis哨兵模式及集群配置

2024-08-30 17:08

本文主要是介绍Redis哨兵模式及集群配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1 Redis安装和配置
    • 1.1 编译环境配置
    • 1.2 Redis安装
      • 1.2.1 使用SecureFX把Redis安装包传到centos
      • 1.2.2 解压redis安装包
      • 1.2.3 编译
      • 1.2.4 安装
      • 1.2.5 Copy文件
  • 2 启动Redis以及客户端
    • 2.1 配置redis.conf文件
    • 2.2 后台启动
    • 2.3 开启客户端
    • 2.4 退出客户端
    • 2.5 关闭redis服务
  • 3 Redis主从复制
    • 3.1 配置方法
      • 3.1.1 创建从机
      • 3.1.2 启动从机和客户端
      • 3.1.3 通过info replication指令查看当前主从机关系
  • 4 哨兵模式
    • 4.1 准备工作
      • 4.1.1 准备若干份的从机
      • 4.1.2 配置哨兵
    • 4.2 启动哨兵
    • 4.3 测试
  • 5 Redis集群
    • 5.1 配置节点
      • 5.1.1 配置单个节点
      • 5.1.2 复制节点若干份。通常组成六个节点的集群,三主三从
    • 5.2 编写脚本启动所有的节点
    • 5.3 执行脚本启动所有节点
    • 5.4 创建cluster
    • 5.5 连接集群
    • 5.6 查看集群信息


1 Redis安装和配置

1.1 编译环境配置

Redis是C语言开发的,安装redis需要先去官网下载源码进行编译,编译需要依赖于GCC编译环境,如果CentOS上没有安装gcc编译环境,需要提前安装,安装命令如下:(这里我们使用root用户处理这些操作)

[root@localhost ~]# yum install gcc-c+

1.2 Redis安装

1.2.1 使用SecureFX把Redis安装包传到centos

1.2.2 解压redis安装包

[root@localhost local]# tar -zxvf redis-5.0.5.tar.gz

1.2.3 编译

在解压的根目录下执行make

[root@localhost local]# cd redis-5.0.5
[root@localhost redis-5.0.5]# make

如果编译失败,需要先删除安装文件目录,后解压重新编译。

1.2.4 安装

[root@localhost redis-5.0.5]# make PREFIX=/home/admin/myapps/redis install

其中PREFIX是自定义的安装目录

1.2.5 Copy文件

Redis启动需要一个配置文件,可以修改端口号信息。将redis解压的文件夹中的redis.conf文件复制到安装目录。

[root@localhost redis-5.0.5]# cp redis.conf /home/admin/myapps/redis

2 启动Redis以及客户端

2.1 配置redis.conf文件

  • 在redis.conf文件中,设置:daemonize yes,允许后台启动
  • 设置绑定ip地址:默认是localhost地址(127.0.0.1),这里需要修改为虚拟机的ip地址(我的是192.168.111.128)。bind 192.168.111.128

2.2 后台启动

[root@localhost redis]# ./bin/redis-server redis.conf

2.3 开启客户端

[root@localhost redis]# ./bin/redis-cli -h 192.168.111.128 -p 6379

2.4 退出客户端

quit

2.5 关闭redis服务

  • 强制关闭:kill -9 pid,其中pid为相关进程的id,可以通过ps -aux | grep redis查看。
  • 正常关闭:./bin/redis-cli -h 192.168.111.128 -p 6379 shutdown

如果不加-h和-p参数,则默认是关闭localhost下的6397端口的服务。

3 Redis主从复制

  • 持久化保证了即使redis服务重启也不会丢失数据,但是当redis服务器的硬盘损坏了可能会导致数据丢失,通过redis的主从复制机制就可以避免这种单点故障(单台服务器的故障)。
  • 主redis中的数据和从上的数据保持实时同步,当主redis写入数据时通过主从复制机制复制到两个从服务上。
  • 主从复制不会阻塞master,在同步数据时,master 可以继续处理client 请求.
  • 主机master配置:无需配置

在这里插入图片描述

3.1 配置方法

主机不需要配置,只配置从机。

3.1.1 创建从机

复制redis目录若干份,对每一份中要做如下操作:

  • redis.conf修改:
    • 修改绑定的端口:port 6380(确保每一个从机的端口不一样)
    • 绑定主机ip和端口:replicaof 主机ip 主机端口号 replicaof 192.168.111.128 6379
  • 删除从机的持久化文件

3.1.2 启动从机和客户端

3.1.3 通过info replication指令查看当前主从机关系

4 哨兵模式

传统的主从关系中,如果主机宕机了,需要手动配置一个从机顶替上来,并且还要修改其他从机与其的关系。通过哨兵模式可以自动化这个过程。

哨兵是一个单独的进程,启动之前确保主从服务是正常的。先启动主服务,后启动从服务

4.1 准备工作

哨兵主要是用来监听主服务器的,所以一般把哨兵部署在从服务器上监听。

4.1.1 准备若干份的从机

  • 删除从机中的持久化文件
  • redis.conf中修改绑定的端口号
  • redis.conf中replicaof的修改,确定主从关系

4.1.2 配置哨兵

哨兵只需要配置其中一个从机即可!!
任选一个从机,在其bin目录下新建文件sentinel.conf,在其中写入内容:

sentinel monitor mastername 192.168.111.128 6379 1
  • mastername 监控主数据的名称,自定义
  • 192.168.111.128:监控主数据库的IP;
  • 6379:端口
  • 1:最低通过票数

4.2 启动哨兵

哨兵可以理解为一个监控的进程。既然要监控,那么首先需要先有监控的对象,即主从机需要先启动。就按照先前的启动方式启动即可。

通过ps -aux | grep redis确定主从机已经启动!

之后启动哨兵:

[root@localhost redis]# ./bin/redis-sentinel ./bin/sentinel.conf > sent.log &

启动之后同样查看进程,如果出现sentinel进程说明已经启动成功!

在这里插入图片描述

查询配置文件sentinel.conf中生成的内容:
启动哨兵的时候,修改了哨兵的配置文件。如果需要再次启动哨兵,需要删除myid唯一标示。(保险的做法就是启动的一次,新配置一次)
在这里插入图片描述

4.3 测试

关闭主机,在从机中通过info replication检查状态,发现某一个从机变为了主机,另一个从机自动绑定到了新主机。

5 Redis集群

集群搭建的总体方法:

  • 先配置并启动若干redis节点
  • 再将这些节点配置为cluster

5.1 配置节点

5.1.1 配置单个节点

  • 删除所有的持久化文件
  • 修改redis.conf:
    • cluster-enabled yes解开注释
    • 修改端口号
    • 如果之前配置过主从机(replicaof),则注释掉这句话

5.1.2 复制节点若干份。通常组成六个节点的集群,三主三从

  • 每个节点需要修改端口号避免重复

5.2 编写脚本启动所有的节点

假定当前的目录为:

|-: redis-cluster|-: 7001|-: 7002......|-: 7006

则在redis-cluster目录下新建startall.sh脚本:

cd 7001
./bin/redis-server ./redis.conf
cd ..
cd 7002
./bin/redis-server ./redis.conf
cd ..
cd 7003
./bin/redis-server ./redis.conf
cd ..
cd 7004
./bin/redis-server ./redis.conf
cd ..
cd 7005
./bin/redis-server ./redis.conf
cd ..
cd 7006
./bin/redis-server ./redis.conf
cd ..
  • 修改脚本的权限,使其能够执行:chmod u+x startall.sh

5.3 执行脚本启动所有节点

./startall.sh

执行完毕后,输入ps -aux | grep redis,会出现六个节点的进程:
在这里插入图片描述

5.4 创建cluster

在任意节点下启动一次即可。

./bin/redis-cli --cluster create 192.168.111.128:7001 192.168.111.128:7002 192.168.111.128:7003 192.168.111.128:7004 192.168.111.128:7005 192.168.111.128:7006 --cluster-replicas 1

基本语法如下:./bin/redis-cli --cluster create ip1:port1 ip2:port2 ... --cluster-replicas 1

  • 其中–cluster-replicas 表示每个主节点配置几个从节点

5.5 连接集群

连接集群内的任意一个节点即可连接到整个集群。

./bin/redis-cli -h 192.168.111.128 -p 7001 -c

注意添加-c命令,表示以集群模式连接
务必关闭防火墙!

  • 关闭防火墙:service iptables stop
  • 查看防火墙状态:service iptables status

5.6 查看集群信息

cluster info
cluster nodes

这篇关于Redis哨兵模式及集群配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121425

相关文章

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤

《SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤》本文主要介绍了SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤,文中通过示例代码介绍的非常详... 目录 目标 步骤 1:确保 ProxySQL 和 mysql 主从同步已正确配置ProxySQL 的

Spring Boot整合log4j2日志配置的详细教程

《SpringBoot整合log4j2日志配置的详细教程》:本文主要介绍SpringBoot项目中整合Log4j2日志框架的步骤和配置,包括常用日志框架的比较、配置参数介绍、Log4j2配置详解... 目录前言一、常用日志框架二、配置参数介绍1. 日志级别2. 输出形式3. 日志格式3.1 PatternL

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

配置springboot项目动静分离打包分离lib方式

《配置springboot项目动静分离打包分离lib方式》本文介绍了如何将SpringBoot工程中的静态资源和配置文件分离出来,以减少jar包大小,方便修改配置文件,通过在jar包同级目录创建co... 目录前言1、分离配置文件原理2、pom文件配置3、使用package命令打包4、总结前言默认情况下,

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Python中操作Redis的常用方法小结

《Python中操作Redis的常用方法小结》这篇文章主要为大家详细介绍了Python中操作Redis的常用方法,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解一下... 目录安装Redis开启、关闭Redisredis数据结构redis-cli操作安装redis-py数据库连接和释放增

redis防止短信恶意调用的实现

《redis防止短信恶意调用的实现》本文主要介绍了在场景登录或注册接口中使用短信验证码时遇到的恶意调用问题,并通过使用Redis分布式锁来解决,具有一定的参考价值,感兴趣的可以了解一下... 目录1.场景2.排查3.解决方案3.1 Redis锁实现3.2 方法调用1.场景登录或注册接口中,使用短信验证码场

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行