centos7下 Mysql+Keepalived 双主热备高可用图文配置详解

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
网络型负载均衡 NLB,每月750个小时 15LCU
简介: centos7下 Mysql+Keepalived 双主热备高可用图文配置详解

环境描述:


Centos7 版本

Master1:192.168.1.146        安装mysql和keepalived

Master2: 192.168.1.147        安装mysql和keepalived

VIP:192.168.1.188

要实现主主同步,可以先实现主从同步,即master1->master2的主从同步,然后master2->master1的主从同步.

这样,双方就完成了主主同步。

 

注意下面几点:

1)要保证同步服务期间之间的网络联通。即能相互 ping 通,能使用对方授权信息连接到对方数据库(防火墙开放3306端口)。

2)关闭selinux。

3)同步前,双方数据库中需要同步的数据要保持一致。这样,同步环境实现后,再次更新的数据就会如期同步了。

这里略过。

配置Mysql+Keepalived故障转移的高可用环境  

1)安装keepalived并将其配置成系统服务。master1和master2两台机器上同样进行如下操作:

[root@master1 ~] # yum install -y openssl-devel popt-devel

[root@master1 ~] # cd /usr/local/src/

[root@master1 src] # wget http://www.keepalived.org/software/keepalived-1.3.5.tar.gz

[root@master1 src] # tar -zvxf keepalived-1.3.5.tar.gz

[root@master1 src] # cd keepalived-1.3.5

[root@master1 keepalived-1.3.5] # ./configure --prefix=/usr/local/keepalived

[root@master1 keepalived-1.3.5] # make && make install

   

[root@master1 keepalived-1.3.5] # cp /usr/local/src/keepalived-1.3.5/keepalived/etc/init.d/keepalived /etc/rc.d/init.d/

[root@master1 keepalived-1.3.5] # cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/

[root@master1 keepalived-1.3.5] # mkdir /etc/keepalived/

[root@master1 keepalived-1.3.5] # cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/

[root@master1 keepalived-1.3.5] # cp /usr/local/keepalived/sbin/keepalived /usr/sbin/

[root@master1 keepalived-1.3.5] # echo "/etc/init.d/keepalived start" >> /etc/rc.local

   

2)master1机器上的keepalived.conf配置。(下面配置中没有使用lvs的负载均衡功能,所以不需要配置虚拟服务器virtual server)

[root@master1 ~] # cp /etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf.bak

[root@master1 ~] # vim /etc/keepalived/keepalived.conf       #清空默认内容,直接采用下面配置:

! Configuration File for keepalived
       
global_defs {
router_id MASTER-HA
}
       
vrrp_script chk_mysql_port {
    script "/etc/keepalived/chk_mysql.sh"
    interval 2            
    weight -5                 
    fall 2                 
    rise 1               
}
       
vrrp_instance VI_1 {
    state MASTER
    interface ens33    
    mcast_src_ip 192.168.1.146
    virtual_router_id 51    
    priority 101          
    advert_int 1         
    authentication {   
        auth_type PASS 
        auth_pass 1111     
    }
    virtual_ipaddress {    
        192.168.1.188
    }
      
track_script {               
   chk_mysql_port             
}
virtual_server 192.168.1.188 3306 {
    delay_loop 6               
    lb_algo wrr             
    lb_kind DR                 
    #nat_mask 255.255.255.0
    persistence_timeout 50     
    protocol TCP              
    
    ## Real Server设置,3306就是连接端口
    real_server 192.168.1.146 3306 {
        weight 3  ##权重
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
            connect_port 3306
        }
    }
    real_server 192.168.1.147 3306 {
        weight 3
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
            connect_port 3306
        }
    }
}
}


master2机器上的keepalived配置。master2机器上的keepalived.conf文件只修改priority为90、nopreempt不设置、real_server设置本地IP。

! Configuration File for keepalived
       
global_defs {
router_id BACKUP-HA
}
       
vrrp_script chk_mysql_port {
    script "/etc/keepalived/chk_mysql.sh"
    interval 2            
    weight -5                 
    fall 2                 
    rise 1               
}
       
vrrp_instance VI_1 {
    state BACKUP
    interface ens33    
    mcast_src_ip 192.168.1.147
    virtual_router_id 51    
    priority 99          
    advert_int 1         
    authentication {   
        auth_type PASS 
        auth_pass 1111     
    }
    virtual_ipaddress {    
        192.168.1.188
    }
      
track_script {               
   chk_mysql_port             
}
virtual_server 192.168.1.188 3306 {
    delay_loop 6               #服务轮询的时间间隔
    lb_algo wrr                #加权轮询调度,LVS调度算法 rr|wrr|lc|wlc|lblc|sh|sh
    lb_kind DR                 #LVS集群模式 NAT|DR|TUN,其中DR模式要求负载均衡器网卡必须有一块与物理网卡在同一个网段
    #nat_mask 255.255.255.0
    persistence_timeout 50     #会话保持时间
    protocol TCP              #健康检查协议
    
    ## Real Server设置,3306就是连接端口
    real_server 192.168.1.146 3306 {
        weight 3  ##权重
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
            connect_port 3306
        }
    }
    real_server 192.168.1.147 3306 {
        weight 3
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
            connect_port 3306
        }
    }
}
}

编写切换脚本。KeepAlived做心跳检测,如果Master的MySQL服务挂了(3306端口挂了),那么它就会选择自杀。Slave的KeepAlived通过心跳检测发现这个情况,

就会将VIP的请求接管

[root@master1 ~]# vim /etc/keepalived/chk_mysql.sh

#!/bin/bash

counter=$( netstat   -na| grep   "LISTEN" | grep   "3306" | wc   -l)

if   [ "${counter}"   - eq   0 ]; then

    /etc/init .d /keepalived   stop

fi

[root@master1 ~]# chmod 755 /etc/keepalived/chk_mysql.sh     

启动keepalived服务

[root@master1 ~] # /etc/init.d/keepalived start

正在启动 keepalived:                                      [确定]

在启动的时候有可能启动失败   打开 vim /lib/systemd/system/keepalived.service  在第7行

PIDFile=/usr/local/program/keepalived/var/run/keepalived.pid      ##发现这个目录不存在,无法写入keepalived.pid  

修改成 PIDFile=/var/run/keepalived.pid

执行 systemctl daemon-reload    #重新载入 systemd,扫描新的或有变动的单元  

在运行就Ok了    /etc/init.d/keepalived start



ip addr 可以看到 vip在master上

三、测试

最简单的测试

mysql -h192.168.1.188 -uroot1 -proot1

show databases;

在147服务上看 ip addr 也可以看到vip漂移到了147服务上

/******************/

上面那个脚本简单且粗暴,即脚本一旦监测到Master的mysql服务关闭,就立刻把keepalived服务关闭,不能实现vip转移,也就是当Master数据库恢复的是时候不能再切回来!

下面这个脚本可以实现 当监测到Master的mysql服务关闭后,就会将vip切换到Backup上 当Master的mysql服务恢复后,就会再次将VIP资源切回来

#!/bin/bash

MYSQL= /usr/local/mysql/bin/mysql

MYSQL_HOST=localhost

MYSQL_USER=root

MYSQL_PASSWORD=123456

CHECK_TIME=3

 

#mysql  is working MYSQL_OK is 1 , mysql down MYSQL_OK is 0

 

MYSQL_OK=1

 

function   check_mysql_helth (){

    $MYSQL -h $MYSQL_HOST -u $MYSQL_USER -p${MYSQL_PASSWORD} -e "show status;"   > /dev/null   2>&1

    if   [ $? = 0 ] ; then

    MYSQL_OK=1

    else

    MYSQL_OK=0

    fi

    return   $MYSQL_OK

}

while   [ $CHECK_TIME - ne   0 ]

do

    let   "CHECK_TIME -= 1"

    check_mysql_helth

if   [ $MYSQL_OK = 1 ] ; then

    CHECK_TIME=0

    exit   0

fi

if   [ $MYSQL_OK - eq   0 ] &&  [ $CHECK_TIME - eq   0 ]

then

    pkill keepalived

    exit   1

fi

sleep   1

done



相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
218
分享
相关文章
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
224 16
|
2月前
|
CentOS7.8配置Adoptium-Java17运行环境
本指南介绍如何设置清华镜像源并安装 Temurin-17-JRE 运行环境。首先,编辑 `/etc/yum.repos.d/adoptium.repo` 文件,配置清华镜像源。接着,使用 `yum install -y temurin-17-jre` 命令安装 Temurin-17-JRE,并通过 `java --version` 验证安装成功。相关配置和操作界面截图附后。
56 8
centos7环境下tomcat8的安装与配置
本文介绍了在Linux环境下安装和配置Tomcat 8的详细步骤。首先,通过无网络条件下的文件交互软件(如Xftp 6或MobaXterm)下载并解压Tomcat安装包至指定路径,启动Tomcat服务并测试访问。接着,修改Tomcat端口号以避免冲突,并部署Java Web应用项目至Tomcat服务器。最后,调整Linux防火墙规则,确保外部可以正常访问部署的应用。关键步骤包括关闭或配置防火墙、添加必要的端口规则,确保Tomcat服务稳定运行。
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
225 3
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
262 2
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
135 42
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
88 25
云数据库:从零到一,构建高可用MySQL集群
在互联网时代,数据成为企业核心资产,传统单机数据库难以满足高并发、高可用需求。云数据库通过弹性扩展、分布式架构等优势解决了这些问题,但也面临数据安全和性能优化挑战。本文介绍了如何从零开始构建高可用MySQL集群,涵盖选择云服务提供商、创建实例、配置高可用架构、数据备份恢复及性能优化等内容,并通过电商平台案例展示了具体应用。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等