`

redis主从切换的集群管理

 
阅读更多

网站的访问量慢慢上来了。为了网站的性能方面,开始用了redis做缓存策略。刚开始的时候,redis是一个单点,当一台机器岩机的时候,redis的 服务完全停止,这时就会影响其他服务的正常运行。费话不多说了,下面利用redis sentinel做一个主从切换的集群管理。做这个集群管理的时候,查过很多资料才完全了解,他是怎么做的。

java 客户端请看:

http://blog.mkfree.com/posts/52b146e6479e5a64742fddd0

参考资料:http://redis.io/topics/sentinel 我也是看这篇文章。

环境配置:

由于我这次配置没有太多的机器,我用了vagrant 去开了多台虚拟机。然后搭好了环境。

redis的安装请参考:redis 简单官方脚本安装方法(linux)

集群配置最少需要三台机器,那么我就三台虚拟机,三台虚拟机分别安装同样的redis的环境

ip分别:

  • 192.168.9.17  (redis sentinel 集群监控)
  • 192.168.9.18  (redis 主)
  • 192.168.9.19  (redis 从)

redis配置:

主的redis配置文件,使用默认的配置文件就可以了,如果你需要设计其他参数

从的redis配置文件,添加

#从的redis配置文件,需要添加
vim /etc/redis/6379.conf
slaveof 192.168.9.18 6379

启动主从redis

#启动主redis192.168.9.18
/etc/init.d/redis_6379.conf start
#启动从redis192.168.9.19
/etc/init.d/redis_6379.conf start

查看主redis信息

#查看主redis的信息
redis-cli -h 192.168.9.18 info Replication

# Replication
role:master #代表192.168.9.18:6379 这台redis是主
connected_slaves:1
slave0:192.168.9.18,6379,online

查看从redis信息

#查看主redis的信息
redis-cli -h 192.168.9.19 info Replication

# Replication
role:slave #代表192.168.9.18:6379 这台redis是主
master_host:192.168.9.18
master_port:6379
master_link_status:up
master_last_io_seconds_ago:4
master_sync_in_progress:0
slave_priority:100
slave_read_only:1
connected_slaves:0

配置redis sentinel集群监控服务 1.添加一份redis sentinel 配置文件

 

vim /etc/redis/sentinel.conf

##redis-0
##sentinel实例之间的通讯端口
port 26379
#master1
sentinel monitor master1 192.168.9.18 6379 1
sentinel down-after-milliseconds master1 5000
sentinel failover-timeout master1 900000
sentinel can-failover master1 yes
sentinel parallel-syncs master1 2

#master2  可以添加多组主从的redis监听
...
..
..

2.有配置文件了,那么启动redis sentinel做redis集群监听redis-sentinel sentinel.conf --sentinel


好了,所有环境都搭好了。下面开始正式的演示 1.正常演示。

 

  • 主的redis启动
  • 把从的redis启动
  • 把redis sentinel 集群监听启动

观察redis sentinel 日志信息

这里很清楚地看到,从的redis加入了集群

[4925] 15 Oct 03:42:21.889 * +slave slave 192.168.9.19:6379 192.168.9.19 6379 @ master1 192.168.9.18 6379

执行以下命令,查看redis主从信息

[root@localhost vagrant]# redis-cli -h 192.168.9.17 -p 26379 info Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
master0:name=master1,status=ok,address=192.168.9.18:6379,slaves=1,sentinels=1

那么表示一切都正常了。你的redis sentinel集群已经配置成功!

 



2.故障演示

 

2.1当主的redis 服务器岩机了,会发生什么情况呢?

执行以下命令使用主的redis服务停止

redis-cli -h 192.168.9.18 -p 6379 shutdown #表示把192.168.9.18这台redis 关闭


 

这张图片很清晰地反应到,redis sentinel 监控到主的redis服务停止,然后自动把从的redis切换到主。

再执行以下命令,查看redis主从信息

[root@localhost vagrant]# redis-cli -h 192.168.33.111 -p 26379 info Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
master0:name=master1,status=ok,address=192.168.9.19:6379,slaves=1,sentinels=1


 

2.2 当我们已经发现,一台redis发生故障了,可能会收到一些故障信息,那么再把服务已关闭的redis恢复服务状态,会发生怎么样的情况呢?

redis sentinel 集群服务,会把上次主redis重新加入服务中,但是他再以不是主的redis了,变成从的reids。

 

分享到:
评论

相关推荐

    Redis主从复制和集群配置

    ### Redis主从复制和集群配置详解 #### 一、Redis主从复制原理及配置 **1.1 概述** Redis的主从复制机制是一种重要的数据同步方式,它支持一个或多个从数据库(slave)与主数据库(master)之间进行数据同步。其中,...

    windows redis 主从集群实例加哨兵集群

    Windows Redis主从集群及哨兵集群的搭建是提高Redis服务的可用性和数据安全性的重要手段。下面将详细介绍这两个概念以及如何在Windows环境中实现。 1. Redis主从集群: 主从复制是Redis提供的一种数据备份和故障...

    redis主从备份双机热备集群简洁配置方式

    redis主从备份双机热备集群简洁配置方式,主要配置redis.conf文件和sentinel.conf文件,可以实现主从自动切换,宕机也不怕

    redis 主从切换 实现HA 的方法和工具

    Redis主从复制是其HA的基础,它允许一个Redis实例(主节点)的数据被多个实例(从节点)实时同步。当主节点出现问题时,可以快速切换到一个从节点继续提供服务。以下是主从复制的基本步骤: 1. 配置主节点:在主...

    docker-compose redis主从哨兵 redis多节点高可用 redis集群高可用

    1. **Redis主从复制**:这是基础的高可用方案,通过将数据实时同步到一个或多个从节点,即使主节点故障,从节点也能无缝接管服务。在Docker Compose文件中,我们需要定义三个服务,一个为主节点,两个为从节点,并...

    redis主从集群 window 64位

    redis主从,只需要在从机上指定主机的ip和端口就完成了。 可以在从机的conf配置文件中增加如下一行: slaveof 127.0.0.1 6379 格式是 slaveof 主机ip 主机上redis的端口 也可以在从机的客户端手工输入这么一行命令...

    xiangfeiZENG#mywiki#redis主从切换的集群管理1

    创建redis运行目录:安装Redis:安装成功后将redis-server、redis-cli、redis-sentinel、redis-check-aof、

    spring cache + redis 主从

    哨兵模式是Redis的一种高可用性解决方案,用于监控Redis主从集群中各个节点的运行状态,实现故障转移。 1. 配置哨兵: - 在每个Redis实例的conf目录下配置sentinel.conf文件。 - 启动哨兵进程,哨兵会自动发现...

    Redis主从切换,哨兵监听切换shell脚本

    由于项目提供两台服务器,想部署Redis的一主两从三哨兵就存在宕机后的一些风险。于是写了个脚本,让这个脚本每5分钟检测一次Redis。让脚本完成主从切换,哨兵监听的切换

    redis主从配置.zip

    Redis是一款高性能的键值对数据库,常用于缓存、消息队列等场景。...总的来说,Redis主从配置是构建高可用Redis集群的基础,通过合理的配置和管理,可以为业务提供高效、稳定的数据存储和访问服务。

    redis主从集群搭建及容灾部署(哨兵sentinel).pdf

    在实际部署和使用过程中,可能会遇到如网络延迟导致的数据同步延迟、主从切换后的数据一致性问题、以及资源消耗过高等问题。解决这些问题通常需要优化网络环境、调整 Redis 参数或采用更高级的数据一致性策略,如 ...

    redis主从服务搭建demo

    首先,我们需要理解Redis主从架构的核心概念。在主从模式下,一个Redis实例作为主节点负责数据的读写操作,而其他实例作为从节点,实时同步主节点的数据,确保在主节点出现故障时,可以从节点接管服务,避免数据丢失...

    redis主从搭建的文档

    通过上述步骤,我们可以成功地搭建并配置一个Redis主从集群。这种方式不仅能够提升系统的读取性能,还能够在一定程度上提高系统的可靠性和可用性。在实际部署过程中,还需要根据具体的应用场景和业务需求来调整配置...

    Redis主从哨兵搭建,conf配置

    在Redis主从结构中,有一个主节点(Master)负责接收写操作,多个从节点(Slave)通过复制主节点的数据保持同步,确保数据的安全性。当主节点出现故障时,从节点可以接管服务,实现故障切换。 1. **安装Redis** 在...

    redis主从配置+sentinel哨兵模式

    通过以上步骤,我们可以成功地搭建一个包含主从复制功能以及 Sentinel 高可用支持的 Redis 集群。这种配置不仅能够提供更高的数据安全性,还能够在主节点发生故障时自动切换到从节点,保证了系统的持续可用性。对于...

    2、redis主从复制以及密码、配置文件启动1

    在本例中,我们将探讨如何设置Redis主从复制,配置密码保护,通过配置文件启动Redis,并引入Sentinel哨兵系统来实现故障切换。 首先,我们需要准备至少三个Redis实例,一个作为主节点(master),两个作为从节点...

    【Redis基础】一起读懂Redis主从架构、哨兵模式、集群(Demo详解)(csdn)————程序.pdf

    在Redis 3.0及之后版本,不再依赖哨兵进行集群管理。集群由多个主节点组成,每个节点都有自己的数据分区,且每个节点都与其他节点保持通信,共同维护整个集群的状态。 集群特点: 1. **无中心**:每个节点都是平等...

    【中间件篇-Redis缓存数据库06】Redis主从复制/哨兵 高并发高可用

    一、Redis主从复制 1. 主从复制的基本概念:主从复制是将一个Redis实例(主节点)的数据实时同步到其他实例(从节点)的过程。这样,即使主节点出现问题,从节点也能立即接管服务,保证系统的连续性。 2. 同步过程...

    redis教程及主从配置和集群搭建

    ### Redis 教程及主从配置和集群搭建 #### Redis 基础知识与应用场景 **Redis**(Remote Dictionary Server)是一种开源的键值(Key-Value)存储系统,使用 C 语言编写,以其高性能和丰富的数据结构而闻名。Redis ...

Global site tag (gtag.js) - Google Analytics