如何在mysql中搭建MHA高可用集群

MHA集群通过主从复制、SSH免密登录和VIP漂移实现MySQL高可用,主库故障时自动选举最优从库升主并重定向服务,确保10-30秒内恢复。

如何在mysql中搭建mha高可用集群

搭建MySQL MHA(Master High Availability)集群可以有效实现主库故障自动切换,保障数据库服务的高可用性。MHA由两部分组成:MHA Manager(管理节点)和MHA Node(数据节点),其核心功能是在主库宕机时,从多个从库中选举出一个最优节点进行主库切换,并将其他从库指向新的主库。

1. 环境准备与基础配置

搭建MHA前需确保以下环境条件:

至少一主多从的MySQL复制架构(推荐一主两从或以上)所有MySQL节点开启binlog、server-id唯一、启用GTID(可选但推荐)各节点之间SSH免密登录(MHA Manager通过SSH管理Node)所有节点安装MHA Node软件包单独一台服务器部署MHA Manager(也可与某个从库共用,但不建议生产环境)

示例拓扑:

主库(Master):192.168.1.10从库1(Slave1):192.168.1.11从库2(Slave2):192.168.1.12MHA Manager:192.168.1.20(可复用某从库)

2. 配置MySQL主从复制

确保主从复制正常运行是MHA的前提。

主库配置(my.cnf):

[mysqld]server-id = 1log-bin = mysql-binbinlog-format = ROWgtid-mode = ONenforce-gtid-consistency = ON

从库配置:

server-id = 2  # 每个从库ID不同relay-log = relay-binlog-slave-updates = ONread-only = ONgtid-mode = ONenforce-gtid-consistency = ON

在主库创建复制用户:

CREATE USER 'repl'@'%' IDENTIFIED BY 'replpass';GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';FLUSH PRIVILEGES;

从库执行CHANGE MASTER命令,启动复制并确认IO/SQL线程运行正常(SHOW SLAVE STATUSG)。

3. 安装MHA Node与Manager

MHA Node需在每个MySQL节点(包括主从)安装:

yum install perl-DBD-MySQL -yrpm -ivh mha4mysql-node-0.58-0.el7.noarch.rpm

MHA Manager只在管理节点安装:

yum install perl-Config-Tiny perl-Log-Dispatch perl-Parallel-ForkManager -yrpm -ivh mha4mysql-manager-0.58-0.el7.noarch.rpm

创建MHA工作目录:

mkdir -p /etc/masterhamkdir -p /var/log/masterha/app1

4. 配置SSH免密登录

在MHA Manager节点生成密钥,并分发到所有MySQL节点:

ssh-keygen -t rsassh-copy-id root@192.168.1.10ssh-copy-id root@192.18.1.11ssh-copy-id root@192.168.1.12

测试SSH互通无密码登录,这是MHA执行远程操作的基础。

集简云 集简云

软件集成平台,快速建立企业自动化与智能化

集简云 22 查看详情 集简云

5. 编写MHA配置文件

创建配置文件 /etc/masterha/app1.cnf:

[server default]manager_workdir=/var/log/masterha/app1manager_log=/var/log/masterha/app1/manager.logmaster_ip_failover_script=/usr/local/bin/master_ip_failovershutdown_script=""ssh_user=rootrepl_user=replrepl_password=replpassping_interval=1master_binlog_dir=/var/lib/mysql

[server1]hostname=192.168.1.10candidate_master=1

[server2]hostname=192.168.1.11candidate_master=1

[server3]hostname=192.168.1.12no_master=1

说明:candidate_master=1 表示可参与主库选举;no_master=1 表示不可升为主库。

6. 配置VIP及故障转移脚本

MHA本身不带VIP漂移功能,需自定义脚本实现。创建 /usr/local/bin/master_ip_failover

#!/usr/bin/perluse strict;use warnings FATAL => 'all';

use Getopt::Long;

my ($command, $ssh_user, $orig_master_host,$orig_master_ip, $orig_master_port, $new_master_host,$new_master_ip, $new_master_port);

GetOptions('command=s' => $command,'ssh_user=s' => $ssh_user,'orig_master_host=s' => $orig_master_host,'orig_master_ip=s' => $orig_master_ip,'orig_master_port=i' => $orig_master_port,'new_master_host=s' => $new_master_host,'new_master_ip=s' => $new_master_ip,'new_master_port=i' => $new_master_port,);

my $vip = '192.168.1.100';my $interface = 'eth0';my $key = '1';my $ssh_start_vip = "sudo /sbin/ifconfig $interface:$key $vip";my $ssh_stop_vip = "sudo /sbin/ifconfig $interface:$key down";

if ( $command eq "stop" || $command eq "stopssh" ) {print "Disabling the VIP on old master: $orig_master_host n";system("ssh $ssh_user@$orig_master_host "$ssh_stop_vip"");}

if ( $command eq "start" ) {print "Enabling the VIP on new master: $new_master_host n";system("ssh $ssh_user@$new_master_host "$ssh_start_vip"");}exit 0;

赋予执行权限:chmod +x /usr/local/bin/master_ip_failover

确保各节点root用户可通过sudo执行ifconfig命令(配置visudo)。

7. 启动MHA并测试故障切换

先检查配置是否正确:

masterha_check_ssh --conf=/etc/masterha/app1.cnf
masterha_check_repl --conf=/etc/masterha/app1.cnf

两项检查均通过后,启动MHA Manager:

nohup masterha_manager --conf=/etc/masterha/app1.cnf --remove_dead_master_conf --ignore_last_failover  /var/log/masterha/app1/manager.log 2>&1 &

模拟主库宕机:

systemctl stop mysqld  # 在主库执行

观察MHA日志(/var/log/masterha/app1/manager.log),会自动完成:

检测主库宕机选择最新数据的从库提升为主库执行VIP漂移脚本重新配置剩余从库指向新主库

基本上就这些。只要主从复制稳定、SSH畅通、脚本权限正确,MHA能快速完成故障切换,通常在10-30秒内恢复服务。注意定期检查MHA状态,避免脑裂或配置遗漏问题。

以上就是如何在mysql中搭建MHA高可用集群的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/298076.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 23:42:48
下一篇 2025年11月4日 23:47:55

相关推荐

  • 解决PHPCMS数据库迁移后网站无法访问的问题

    phpcms迁移后网站无法访问,核心解决方法是检查数据库连接配置并清除缓存。1. 检查 config.inc.php 文件中的 db_host、db_user、db_pwd、db_name、db_pre 和 db_port 参数是否匹配新服务器环境;2. 清除 caches 目录下的所有缓存文件(包…

    2025年12月11日 好文分享
    000
  • 解决Drupal 9 SQLite数据库“尝试写入只读数据库”错误

    本文将围绕解决Drupal 9在使用SQLite数据库时遇到的“尝试写入只读数据库”错误展开。该错误通常是由于文件/文件夹权限或SELinux策略配置不当引起的。我们将详细介绍如何诊断和解决这些问题,确保Drupal 9项目能够正常运行。 当Drupal 9项目使用SQLite数据库时,可能会遇到以…

    2025年12月11日
    000
  • 博客系统怎么开发?PHP+MySQL实战

    开发博客系统数据库设计需清晰可扩展,核心包括users、posts、comments、categories四张表。users表存储用户信息如id、username、password等;posts表记录文章详情,关联users和categories;comments表管理评论,与posts和users…

    2025年12月11日 好文分享
    000
  • 分页功能如何实现?LIMIT与页码计算

    分页功能通过offset和limit截取数据实现。1.分页核心是计算偏移量(offset=(页码-1)每页条数)和限制数量;2.使用sql的limit子句或数据库特定语法(如sql server的offset…fetch next)执行查询;3.前端传页码和每页大小,后端计算偏移量并执行…

    2025年12月11日 好文分享
    000
  • PHP中如何实现多线程?pcntl扩展使用详解

    php中实现多线程需借助pcntl扩展,其核心是通过多进程模拟并发。1. pcntl扩展用于unix/linux系统下的进程控制,提供pcntl_fork()、pcntl_wait()等函数创建和管理子进程。2. 使用pcntl_fork()创建子进程时,返回值为-1表示失败,0表示子进程,大于0表…

    2025年12月11日 好文分享
    000
  • 如何在PHPMyAdmin中设置用户的访问限制

    要精确在phpmyadmin中限制用户访问权限,1. 以管理员身份登录phpmyadmin;2. 进入“用户账户”选项卡;3. 创建新用户或编辑现有用户;4. 设置主机、用户名和密码;5. 在全局权限中避免勾选高危权限如super、grant option;6. 在数据库特定权限中选择目标数据库并分…

    2025年12月11日 好文分享
    000
  • 使用 mPDF 自定义 PDF 下载文件名

    本文档旨在指导开发者在使用 mPDF 库生成 PDF 文件并提供下载时,如何自定义下载的文件名。通过示例代码和详细说明,帮助开发者根据需求动态设置 PDF 文件名,例如使用用户名或其他相关信息。 自定义 PDF 文件名的方法 在使用 mPDF 生成 PDF 文件时,$mpdf->Output(…

    2025年12月11日
    000
  • Windows系统下PHPCMS的安装与环境搭建

    安装phpcms需先搭建集成环境,再部署文件、创建数据库并运行安装向导。1.选择xampp等集成环境,安装php 5.6左右版本以确保兼容性;2.将phpcms解压后复制至htdocs目录并改名;3.通过phpmyadmin创建utf8字符集数据库;4.访问本地地址进入安装向导,完成许可协议、环境检…

    2025年12月11日 好文分享
    000
  • PHP代码打包:Phar文件创建

    如何将php代码打包成phar文件?答案是使用php内置的phar类,按照流程创建并设置。具体步骤包括:1.准备项目结构,确保入口文件明确;2.通过new phar()创建phar对象;3.使用buildfromdirectory()或addfile()添加文件;4.调用setstub()设置入口文…

    2025年12月11日 好文分享
    000
  • 如何防止SQL注入攻击?预处理语句安全实践指南

    防止sql注入的关键在于使用预处理语句并遵循安全实践。1. 使用参数化查询,避免手动拼接sql语句;2. 绑定用户输入而非直接拼接,确保输入不会被当作sql执行;3. 注意orm框架中是否启用参数化查询;4. 避免动态拼接列名或表名,采用白名单校验;5. 正确处理in子句等特殊场景,依据数据库支持方…

    2025年12月11日 好文分享
    000
  • PHPMyAdmin操作数据库时出现“磁盘空间不足”的应对措施

    清理磁盘空间并优化数据库配置是解决phpmyadmin无法正常操作数据库问题的关键。1. 清理无用数据,如删除过期日志;2. 归档历史数据,例如将旧订单移至单独的历史表;3. 优化表结构,使用合适字段类型并去除冗余字段;4. 使用optimize table命令压缩数据库文件;5. 分离大字段到独立…

    2025年12月11日 好文分享
    000
  • PDF怎样生成?TCPDF与DomPDF对比

    tcpdf适合高性能和精细控制,dompdf适合快速开发。1.tcpdf更底层灵活,性能好,控制力强,但学习曲线陡,html支持有限;2.dompdf基于html/css,易上手,开发快,但性能较差,控制力弱,css支持不完整。根据需求选择:大量数据或精确布局选tcpdf,熟悉html/css且追求…

    2025年12月11日 好文分享
    000
  • 怎样用PHP发送带附件的邮件?PHPMailer完整使用教程

    使用phpmailer发送带附件的邮件需依次完成以下步骤:1. 安装phpmailer,推荐通过composer安装或手动引入;2. 实例化对象并配置smtp参数,包括服务器地址、身份验证、加密方式等;3. 设置发件人、收件人、主题和正文内容;4. 使用addattachment()方法添加一个或多…

    2025年12月11日 好文分享
    000
  • PHP怎样转换字符串编码 PHP编码转换的常见问题解决

    php转换字符串编码的核心是使用mb_convert_encoding函数,但需确保环境已启用mbstring扩展。1.确定原始编码,可通过mb_detect_encoding检测或手动指定;2.使用mb_convert_encoding进行转换,并处理失败情况;3.检查php.ini中是否启用mb…

    2025年12月11日 好文分享
    000
  • 掌握PhpStorm的数据库管理工具进行数据操作

    phpstorm 的数据库工具可高效完成数据库操作无需切换软件。要连接数据库,点击右侧 database 面板添加数据源,填写主机地址、端口、用户名、密码等信息并测试连接;常见问题包括权限设置、驱动版本及 ssl 配置。连接成功后可浏览表结构、查看字段与索引,双击表名即可打开查询窗口查看数据,默认显…

    2025年12月11日 好文分享
    000
  • PHP连接MySQL数据库怎么做?PDO连接方式详解

    pdo 是 php 中用于连接数据库的统一接口,支持多种数据库类型并具备安全性与面向对象特性。其核心优势是预处理语句,可有效防止 sql 注入。使用 pdo 连接 mysql 需确保开启了 php_pdo_mysql 扩展,并通过 dsn 指定主机、数据库名和字符集等信息进行连接。常见问题包括:1.…

    2025年12月11日 好文分享
    000
  • PHP高并发:连接池优化方案

    php连接池优化可通过复用数据库连接提升高并发性能。1.选择合适的连接池实现:使用第三方库如doctrine dbal或laravel database获取完善的连接池管理功能;2.配置合理的连接池参数:设置最大连接数、最小空闲连接数、连接超时时间并监控连接泄漏;3.优化数据库查询:使用索引、避免全…

    2025年12月11日 好文分享
    000
  • PHP如何获取虚拟机状态 使用PHP监控VM状态的3种方法

    php获取虚拟机状态的方法有三种:1. 通过命令行工具获取状态,使用exec()函数执行相关命令并解析结果;2. 使用api接口,通过curl或soap客户端调用虚拟机管理软件的restful或soap api获取数据;3. 读取日志文件,利用php读取virtualbox等日志文件并通过正则表达式…

    2025年12月11日 好文分享
    000
  • 利用PHPMyAdmin为用户设置临时权限的方法

    通过phpmyadmin为用户设置临时权限的步骤如下:1. 使用高权限账户登录并选择数据库;2. 进入“权限”选项卡,选择或创建用户;3. 点击“编辑权限”,勾选所需权限(如select、insert等)并执行;4. 记录赋权时间以便后续撤销;5. 权限到期后,再次进入权限管理界面取消相应权限,或运…

    2025年12月11日 好文分享
    000
  • PHP警告:解决“Illegal string offset”错误及变量初始化最佳实践

    本文旨在深入解析PHP中常见的“Illegal string offset”警告,该警告通常发生于尝试将字符串类型变量作为数组使用时。我们将通过分析错误根源,提供正确的变量初始化方法,并探讨相关的编程最佳实践,帮助开发者避免此类问题,确保代码的健壮性和可维护性。 理解“Illegal string …

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信