基于keepalived搭建mysql双主高可用

2024-04-30 12:58

本文主要是介绍基于keepalived搭建mysql双主高可用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 概述
  • 环境准备
  • keepalived搭建
  • mysql搭建
  • mysql双主搭建
  • mysql双主高可用搭建

概述

    传统(不借助中间件)的数据库主从搭建,如果主节点挂掉了,从节点只能读取无法写入,只能把人肉去恢复故障,既不想引用中间件也不想人肉恢复故障,可以折中选择双主方案,本文将介绍通过keepalived搭建mysql双主方案。

    本例中vip为:172.16.0.169,  两台mysql实例服务器ip分别为:172.16.0.1和172.16.0.2

转帖请注明来源: https://my.oschina.net/u/2342969/blog/2963153

环境准备

  1. 最小化安装centos7
  2. mysql-5.7.23
  3. keepalived 1.4.5
  4. 虚拟ip(下文简称vip):172.16.0.169

keepalived搭建

    点击查看keepalived搭建教程,博主亲自操作过来的,如有疑问欢迎随时私信或者评论

mysql单机搭建

    点击查看mysql搭建教程,博主亲自操作过来的,如有疑问欢迎随时私信或者评论

双主搭建

    本方案仅限两台均是全新安装的mysql,如果是旧mysql实例和新mysql实例改为双主,在新mysql实例中记得导入旧mysql实例的数据,另外可能同步复制还会报异常,自行解决一下。

环境安装检查

  1. 两台mysql实例均可以访问
  2. keepalived可以正常漂移

数据库配置更改

#vim /etc/my.cnf

    进入mysql配置修改一下配置:

  1. server-id 两台mysql要不一样,一般是ip最后一位。注意命名规范不要加下划线/中横线/点等特殊符号
  2. #skip_slave_start = 1  注释掉这个配置

创建复制账号

mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'172.16.0.%' identified by 'repl_password';
mysql> flush privileges;
mysql> select @@server_id;

两台mysql分别执行以上语句,语句解析:

  1. 创建mysql复制账号
  2. repl_user: 复制权限账号的用户名,可自行更改
  3. 172.16.0.%: 此处使用的通配符,也可以写固定ip,可同步的mysql实例ip
  4. repl_password: 复制权限账号的密码,自行更改
  5. select @@server_id; 查询出的结果一定要不一样

配置互为主备   

mysql> CHANGE MASTER TO MASTER_HOST="对方ip", MASTER_USER="repl_user", MASTER_PASSWORD="repl_password", MASTER_PORT=3316, MASTER_AUTO_POSITION = 1;
mysql> start slave;
mysql> show slave status\G;

两台mysql分别执行以上sql,语句解析:

  1. 互相设置对方为主节点,自己为备节点
  2. MASTER_HOST:对方ip
  3. MASTER_USER:对方复制权限账号用户名,即上一步设置的用户名
  4. MASTER_PASSWORD:对方复制权限账号密码,即上一步设置的密码
  5. MASTER_PORT:对方mysql实例的端口, 如果开了防火墙一定要记得打开端口
  6. show slave status\G; 注意查看Slave_IO_Running 和 Slave_SQL_Running 状态如果有一个为no 就代表配置失败

检查点:

  1. Master_Host: 是否是对方ip
  2. Master_User: 是否是对方的复制账号的用户名
  3. Master_Port: 是否是对方mysql实例的端口号
  4. Last_SQL_Errno:最近sql错误条数,正常情况为0
  5. Last_SQL_Error:最新sql错误详细信息,正常情况为空

如果有异常,根据异常信息解决掉问题后,执行一下命令

mysql> stop slave;
mysql> reset master;

两台mysql分别执行以上命令,再执行一下上一步的配置。

验证

  1. 在任意一台mysql创建数据库,另一台也会同步到
  2. 在任意一台mysql创建表,另一台也会同步到
  3. 在任意一台mysql表中插入数据,另一台也会同步到

双主高可用

修改keepalived配置

# vim /etc/keepalived/keepalived.conf

配置内容如下:

! Configuration File for keepalived
global_defs {
router_id MYSQL-1 ## 名称自定义,两台机器需要不一样
}vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id 60
priority 100    # 两台机器需要一个大一个小,数值大的先启动,哪台先启动vip会先在哪台机器
advert_int 1
nopreempt
authentication {
auth_type PASS
auth_pass 123456
}
virtual_ipaddress {
172.16.0.169    # 填写自己的vip
}
}virtual_server 172.16.0.169 3316 {  # 填写自己的vip 和mysql端口
delay_loop 2
#lb_algo rr
#lb_kind DR
persistence_timeout 60
protocol TCP
real_server 172.16.0.1 3316 { # 填写mysql服务器真实ip 和mysql端口
weight 3
notify_down /etc/keepalived/checkmysql.sh  # 检查mysql是否存活脚本,根据脚本位置自行填写
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
connect_port 3316  # mysql的端口号
}
}
}

注意: 上面配置注释的部分,两台机器根据实际情况修改,配置文件中的注释一定要去掉,以免出现奇怪问题

编写mysql监测脚本

#vim  /etc/keepalived/checkmysql.sh

脚本内容如下:

#!/bin/sh
datetime=`date +20\%y\%m\%d_\%H\%M\%S`
isok=$(/usr/local/mysql/bin/mysql -h localhost -u数据库账号 -p数据库密码 -P数据库端口 -S /tmp/mysql3316.sock 2>/dev/null  -e 'select 1' |sed -n '2p')
function error_query(){
systemctl stop keepalived
echo $datetime  >> /etc/keepalived/keepalived.log
echo "mysql down, keepalived 切换" >> /etc/keepalived/keepalived.log
}
echo "isok: $isok"  >> /etc/keepalived/keepalived.log
if [ "$isok" != "1" ]
then
error_query
fi

注意:根据实际情况调整脚本中的中文部分

给脚本赋权限:

# chmod +x /etc/keepalived/*.sh

这篇关于基于keepalived搭建mysql双主高可用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

MySQL 衍生表(Derived Tables)的使用

《MySQL衍生表(DerivedTables)的使用》本文主要介绍了MySQL衍生表(DerivedTables)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录一、衍生表简介1.1 衍生表基本用法1.2 自定义列名1.3 衍生表的局限在SQL的查询语句select