我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Redis主从架构和高可用性实现过程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Redis主从架构和高可用性实现过程

还是迁移的事

Redis主从架构和高可用性实现

引言

在当今的应用程序中,高可用性和性能是至关重要的。本文将介绍如何使用Redis主从架构和Linux虚拟服务器(LVS)实现高可用性,同时还会详细介绍最近完成的Redis集群迁移部署的过程。

什么是Redis?

Redis是一个开源的内存数据库,它被广泛用于缓存和数据存储。它以其出色的性能和灵活的数据结构支持而闻名,因此被许多大规模应用程序广泛使用。

Redis主从架构

Redis采用了主从复制的架构,这是一种实现高可用性和横向扩展的方式。在Redis主从架构中,有一个主服务器和多个从服务器,主服务器用于写入操作,从服务器用于读取操作。这可以提高性能和数据冗余。

主服务器

主服务器接收客户端的写入请求,并将这些请求复制到从服务器。它负责数据的写入和维护。

从服务器

从服务器复制主服务器的数据,并用于读取操作。如果主服务器发生故障,从服务器可以升级为主服务器,以保持高可用性。

Redis高可用性

高可用性是确保系统在面临故障时仍然可用的能力。使用Redis主从架构,可以实现高可用性。但为了进一步提高可用性,我们可以引入Linux虚拟服务器(LVS)。

Linux虚拟服务器(LVS)

LVS是一个用于负载均衡的Linux内核模块。我们这里用到的是实现主从切换,当主服务redis异常时,可以切换从服务器变为主服务器。

最近的迁移部署过程

迁移计划

在介绍Redis主从架构和LVS之后,让我们回顾一下最近的Redis集群迁移部署过程。在迁移之前,我们制定了详细的迁移计划和测试流程。

数据备份

首先,我们对现有的Redis集群进行了数据备份。这是确保在迁移期间不会丢失任何数据的关键步骤。我们使用了Redis的快照功能来创建数据备份。

redis部署

在备份完成后,我们进行了网络切换。我们将流量从旧的Redis集群切换到新的Redis集群,同时引入了LVS以实现负载均衡。这个过程需要谨慎地调整网络配置,以确保平滑切换。

redis部署很简单,直接编译安装就好,因为我们是迁移,所以直接把老的包拿过来用即可

主redis配置文件

# cat redis.conf
daemonize yes
pidfile "/var/run/redis.pid"
port 16465
timeout 300
tcp-keepalive 60
loglevel notice
logfile "/data/log/redis.log"
databases 16
stop-writes-on-bgsave-error no
rdbcompression yes
rdbchecksum yes
dbfilename "dump.rdb"
dir "/data/datafile"
masterauth "password"
slave-serve-stale-data yes
slave-read-only yes
repl-ping-slave-period 10
repl-timeout 600
repl-disable-tcp-nodelay no
repl-backlog-size 64mb
repl-backlog-ttl 3600
slave-priority 100
requirepass "password"
maxmemory 10000000000
maxmemory-policy noeviction
appendonly no
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
Lua-time-limit 5000
slowlog-log-slower-than 20000
slowlog-max-len 128
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 8gb 4gb 600
client-output-buffer-limit pubsub 32mb 8mb 60
aof-rewrite-incremental-fsync yes
lazyfree-lazy-expire yes
lazyfree-lazy-server-del yes
slave-lazy-flush yes
aof-use-rdb-preamble yes
maxclients 4064

从redis配置文件会多一行

slaveof 主ip 16465

启动Redis

 /data/redis/bin/redis-server /data/redis/conf/redis.conf

查看info信息,确认主可以连接到从库

lvs部署及配置

keepalive可以直接yum安装

然后修改keepalived配置文件

# cat /etc/keepalived/keepalived.conf 
global_defs {   
        router_id LVS_DEVEL
        script_user root
        enable_script_security    
}
vrrp_script chk_16465 {
        script "/var/keepalived/scripts/redis_check.sh password 16465"
        interval 1
        weight -20
        rise 3
        fall 3
}
vrrp_instance redis_6465 {
        state BACKUP
        interface bond1
        virtual_router_id 52
        priority 90
        advert_int 1
        authentication {
                auth_type PASS
                auth_pass 1111
        }
        virtual_ipaddress {
                vip
        }
        track_script {
                chk_16465
        }
        notify_master "/var/keepalived/scripts/redis_master.sh  password 16465"
        notify_backup "/var/keepalived/scripts/redis_slave.sh  password 16465 masterip  "
        notify_fault "/var/keepalived/scripts/redis_falut.sh"
        notify_stop "/var/keepalived/scripts/redis_stop.sh"
}

如果是主的话,需要对应修改如下:

state MASTER
priority 100

其中涉及到几个脚本,如下:

#cat /var/keepalived/scripts/redis_check.sh 
#!/bin/bash
CMD_RES=`/paic/redis/4.0.10/bin/redis-cli -a $1 -p $2 PING 2>/dev/null`
LOG_FILE="/var/keepalived/logs/redis-state.log"
if [ "$CMD_RES"x == "PONG"x ]; then :
   echo "[CHECK] `date`, SUCCESS" >> $LOG_FILE 2>&1
    exit 0
else
    echo "[CHECK] `date`, ERROR" >> $LOG_FILE 2>&1
    exit 1
fi
# cat /var/keepalived/scripts/redis_master.sh 
#!/bin/bash
CMD="/paic/redis/4.0.10/bin/redis-cli"
LOG_FILE="/var/keepalived/logs/redis-change.log"
echo "[MASTER] `date`" >> $LOG_FILE
echo "Run SLAVEOF NO ONE cmd" >> $LOG_FILE
$CMD -a $1 -p $2 SLAVEOF NO ONE >> $LOG_FILE 2>&1
#cat /var/keepalived/scripts/redis_slave.sh 
#!/bin/bash
CMD="/paic/redis/4.0.10/bin/redis-cli"
LOG_FILE="/var/keepalived/logs/redis-change.log"
echo "[BACKUP] `date`" >> $LOG_FILE
echo "Being slave wait to sync data" >> $LOG_FILE
sleep 1  
echo "Run SLAVEOF cmd" >> $LOG_FILE
$CMD -a $1 -p $2 SLAVEOF $3 $2 >> $LOG_FILE  2>&
#cat /var/keepalived/scripts/redis_falut.sh 
#!/bin/bash
LOG_FILE="/var/keepalived/logs/redis-state.log"
echo "[FAULT] `date`" >> $LOG_FILE

测试

迁移完成后,我们进行了一系列测试,以确保新的Redis集群能够正常工作。我们模拟了各种故障情况,以验证高可用性配置的有效性。

当把主的redis进程kiil掉后,可以看到虚拟ip转移到从机上,通过redis-cli链接后,从redis可以正常写,并且角色转换为了master。

结论

通过使用Redis主从架构和Linux虚拟服务器,我们成功地实现了高可用性和性能扩展。最近的Redis集群迁移部署过程也顺利完成,我们现在拥有一个稳定和可靠的Redis环境,满足了我们应用程序的需求。

Redis的强大性能和高可用性使其成为许多应用程序的首选数据库引擎。希望本文对您理解Redis主从架构、高可用性和迁移部署过程有所帮助。

到此这篇关于Redis主从架构和高可用性实现的文章就介绍到这了,更多相关Redis主从架构和高可用性内容请搜索编程网(www.lsjlt.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.lsjlt.com)!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Redis主从架构和高可用性实现过程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Redis主从架构和高可用性实现过程

目录Redis主从架构和高可用性实现引言什么是Redis?Redis主从架构主服务器从服务器Redis高可用性linux虚拟服务器(LVS)最近的迁移部署过程迁移计划数据备份redis部署测试结论还是迁移的事Redis主从架构和高可用性实
Redis主从架构和高可用性实现过程
2024-09-27

Redis搭建主从复制实现高可用(如何保证 Redis 主从复制的高可用性?)

高可用 HA(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间。
Redis搭建主从复制实现高可用(如何保证 Redis 主从复制的高可用性?)
2024-11-01

MySQL中的主从复制和高可用架构

MySQL中的主从复制和高可用架构随着互联网应用和数据量的不断增长,数据库的高可用性和可扩展性变得越来越重要。MySQL作为一种使用广泛的开源关系型数据库,提供了主从复制和高可用架构的解决方案。主从复制是指将一个MySQL数据库实例作为主库
2023-10-22

docker安装Redis高可用实现一主二从三哨兵

Redis高可用一主二从三哨兵指南本指南详细介绍了在Docker环境中使用主从复制和哨兵机制实现Redis高可用。具体实施步骤包括:创建Redis容器(主、从)配置主从复制创建哨兵容器配置哨兵监控测试故障切换该部署提供数据冗余、自动故障切换、可扩展性和高可用性,确保Redis服务在意外事件中保持可用。
docker安装Redis高可用实现一主二从三哨兵
2024-04-02

如何通过SSH实现高可靠性的Linux SysOps架构设计

要通过SSH实现高可靠性的Linux SysOps架构设计,可以采取以下几个步骤:1. 多节点部署:使用多个节点来实现高可靠性架构。可以使用主从模式、集群或者分布式架构等方式进行部署。这样即使某个节点出现故障,其他节点也可以继续提供服务。2
2023-10-09

使用Docker Compose、Nginx和MariaDB构建高可用性的PHP应用程序架构

概述:在开发和部署PHP应用程序时,构建一个高可用性的架构是非常重要的。通过使用Docker Compose、Nginx和MariaDB,我们可以实现一个可靠和可伸缩的应用程序架构。本文将介绍如何使用这些工具搭建一个高可用性的PHP应用程序
2023-10-21

JavaScript MVC架构的最佳实践:提高应用程序性能和可维护性的技巧

JavaScript MVC架构是构建高效、可维护的前端应用程序的常见方法。本文分享了在JavaScript MVC架构中提高应用程序性能和可维护性的技巧,包括使用模块化设计、优化事件委托、合理使用AJAX请求、采用虚拟DOM技术等。
JavaScript MVC架构的最佳实践:提高应用程序性能和可维护性的技巧
2024-02-12

Golang RabbitMQ: 实现高可用的消息队列系统的架构设计和实现

实现高可用的消息队列系统的架构设计和实现可以通过使用RabbitMQ来完成。RabbitMQ是一个开源的消息中间件,它基于AMQP协议,提供了可靠的消息传递和可扩展的架构。下面是一个基于Golang和RabbitMQ的高可用消息队列系统的架
2023-10-08

通过golang实现高可用性的Select Channels Go并发式编程

在Go语言中,可以使用select语句和通道(channel)来实现高可用性的并发编程。首先,我们定义一个用于处理任务的工作器函数:```gofunc worker(id int, tasks for task := range tasks
2023-10-10

Golang与RabbitMQ实现消息持久化、数据安全和高可用的架构设计和实现

要实现消息持久化、数据安全和高可用的架构设计和实现,可以使用Golang和RabbitMQ的组合。下面是一个简单的架构设计和实现示例:1. 架构设计:- 使用RabbitMQ作为消息中间件,负责消息的传递和存储。- 使用Golang编写消费
2023-10-20

编程热搜

目录