KeepAlived+Redis+Haproxy实现主从热备、负载均衡、秒级切换

本文详细介绍了一种基于Redis集群、HAProxy负载均衡、Keepalived主从热备的高可用架构部署方案。通过三个主要步骤,即部署Redis集群、配置HAProxy实现访问轮询、及使用Keepalived确保主从热备与秒级切换,来保障系统的稳定性和可靠性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、部署Redis集群

1、环境

  • 3台虚拟机模拟6个节点,一台机器2个节点,创建出3 master、3 salve 环境
  • redis1: 192.168.122.34
  • redis2: 192.168.122.22
  • redis3: 192.168.122.188
[root@redis1 ~]# getenforce 
Disabled
[root@redis1 ~]# systemctl status firewalld.service 
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
   Active: inactive (dead)
     Docs: man:firewalld(1)
     
[root@redis1 ~]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.122.34 redis1
192.168.122.22 redis2
192.168.122.188 redis3

[root@redis2 ~]# getenforce 
Disabled
[root@redis2 ~]# systemctl status firewalld.service 
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
   Active: inactive (dead)
     Docs: man:firewalld(1)
     
[root@redis2 ~]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.122.34 redis1
192.168.122.22 redis2
192.168.122.188 redis3
[root@redis3 ~]# getenforce 
Disabled
[root@redis3 ~]# systemctl status firewalld.service 
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
   Active: inactive (dead)
     Docs: man:firewalld(1)

[root@redis3 ~]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.122.34 redis1
192.168.122.22 redis2
192.168.122.188 redis3

2、安装 redis 实例 (6节点)

在redis1 redis2 redis3执行此脚本,安装redis。

#!/usr/bin/env bash
#make install redis
network(){
   
    ping -c2 www.baidu.com &>/dev/null
    if [ $? -ne 0 ];then
        echo "network is error...."
        exit
     
    fi
    
}

test(){
   
[ $? -ne 0 ] && echo "excution error....";exit

}

install_gcc(){
   
    yum -y install gcc glibc glibc-kernheaders  glibc-common glibc-devel make
    yum -y install centos-release-scl
    yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils
#    scl enable devtoolset-9 bash
    source /opt/rh/devtoolset-9/enable
    echo "source /opt/rh/devtoolset-9/enable" >>/root/.bashrc
}
install_redis(){
   
    
    wget http://download.redis.io/releases/redis-6.0.8.tar.gz
    tar -zxvf redis-6.0.8.tar.gz -C /usr/local
    mv /usr/local/redis-6.0.8 /usr/local/redis
    cd /usr/local/redis
    make && make all

}
redis_MS(
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值