Mysql实现MHA高可用

  • 环境:
  • 一、配置MHA:

  • 1、配置所有主机(包括Manager主机在内),实现ssh-key可以相互登陆
    • 当配置文件中的ssh_user为非root用户时:

      (1)需要手动创建node节点主机的文件夹,并授权node主机remote_workdir目录的权限给ssh_user用户
      (2)添加用户为MySQL同组用户,使其有读取mysql binary/relay log文件和relay_log.info文件的权限
      (3)授权Mysql日志目录的写权限
  • 2、配置MHA的配置文件,并且安装mha4mysql-manager、 mha4mysql-node
    • (1)创建并修改配置文件/etc/mastermha/app1.cnf

      #配置文件可以放在任意路径下,因为后面命令调用配置文件时需要写出完整路径。
      
      [server default]
      user=mhauser            #mysql用户
      password=centos         #mysql用户密码
      manager_workdir=/data/mastermha/app1/           #Manager主机的工作目录
      manager_log=/data/mastermha/app1/manager.log    #Manager主机的日志
      remote_workdir=/data/mastermha/app1/            #nodo主机的工作目录
      ssh_user=root           #远程Linux主机系统用户
      repl_user=repluser      #主从复制时使用的mysql用户
      repl_password=centos    #主从复制时使用的mysql密码
      ping_interval=1         #健康检查间隔时间,单位为秒
      
      [server1]
      hostname=192.168.1.4    #mysql主机IP
      candidate_master=1      #是否为备用主库
      [server2]
      hostname=192.168.1.6
      candidate_master=1      #是否为备用主库
      [server3]
      hostname=192.168.1.8

    • (2)安装mha4mysql-manager、 mha4mysql-node
    #事先下载好manager和node,并且版本要一致!!!使用yum安装,需要启用epel源。
    yum install mha4mysql-manager-0.55-0.el6.noarch.rpm   mha4mysql-node-0.55-0.el6.noarch.rpm 
  • 二、主库配置

    • (1)修改mysql配置文件

      vi /etc/my.cnf
      
      [mysqld]
      log-bin
      server_id=1
      innodb_file_per_table
      skip_name_resolve=1

    • (2)安装mha4mysql-node
      yum install mha4mysql-node-0.55-0.el6.noarch.rpm
    • (3)创建mysql用户;主从同步需要一个用户,MHA需要一个用户。
        #MHA切换主库时需要修改Mysql运行时的全局变量,所以需要给所有权限,建议限制用户的登陆IP为特定主机。
    
        mysql>show master logs;
        mysql>grant replication slave on *.* to ‘repluser‘@‘192.168.1.%‘ identified by ‘centos‘;
        mysql>grant all on *.* to ‘mhauser‘@‘192.168.1.%‘ identified by ‘centos‘;
    

  • 三、从库1(备用主库)配置:

    • (1)修改配置文件

      [mysqld]
      server_id=2             #备用主库需要启用二进制日志!!!
      log-bin                 #备用主库需要启用二进制日志!!!
      read_only               #备用主库需要启用二进制日志!!!
      relay_log_purge=0
      skip_name_resolve=1     #禁止名字解析
      innodb_file_per_table

    • (2)安装mha4mysql-node

      yum install   mha4mysql-node-0.55-0.el6.noarch.rpm
    • (3)设置主从同步
      mysql>CHANGE MASTER TO MASTER_HOST=‘192.168.1.4‘, MASTER_USER=‘repluser‘, MASTER_PASSWORD=‘centos‘, MASTER_LOG_FILE=‘mariadb-bin.000001‘, MASTER_LOG_POS=245;

  • 四、从库2配置:

    • (1)修改配置文件

      [mysqld]
      server_id=3
      read_only
      relay_log_purge=0
      skip_name_resolve=1     #禁止名字解析
      innodb_file_per_table

    • (2)安装mha4mysql-node
      yum install    mha4mysql-node-0.55-0.el6.noarch.rpm
    • (3)设置主从同步
      mysql>CHANGE MASTER TO MASTER_HOST=‘192.168.1.4‘, MASTER_USER=‘repluser‘, MASTER_PASSWORD=‘centos‘, MASTER_LOG_FILE=‘mariadb-bin.000001‘, MASTER_LOG_POS=245;

  • 五、检查并启用MHA

    • (1)检查SSH连接

      masterha_check_ssh --conf=/etc/mastermha/app1.cnf 

    • (2)检查node节点
    masterha_check_repl --conf=/etc/mastermha/app1.cnf

  • (3)启动脚本,当检测到主库无法连接就会退出,并提升从库为主库。
    masterha_manager --conf=/etc/mastermha/app1.cnf
    
  • 错误日志:/data/mastermha/app1/manager.log
  • 当MHA短时间内频繁的切换主库时,可能会报错,删除/data/mastermha/app1/app1.failover.complete即可!
  • 原文地址:http://blog.51cto.com/bigboss/2095443

    时间: 2024-10-09 05:37:39

    Mysql实现MHA高可用的相关文章

    MySQL数据库——MHA高可用集群架构(实战!!!)

    MHA 简介 (1)简介 目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开发,是一套优秀的作为MySQL高可用性环境下故障切换和主从提升的高可用软件.在MySQL故障切换过程中,MHA能做到在0~30秒之内自动完成数据库的故障切换操作,并且在进行故障切换的过程中,MHA能在最大程度上保证数据的一致性,以达到真正意义上的高可用. (2)该软件由两部分组成 MHA Manager(管理节点)和MHA Node(数据节点)

    MySQL数据库---MHA高可用群集架构

    MHA概述 日本DeNA公司youshimaton (现就职于Facebook公司) 开发 一套优秀的作为MySQL高可用性环境下故障切换和主从提升的高可用软件 MHA的组成 MHA Manager (管理节点) MHA Node (数据节点) MHA特点 自动故障切换过程中,MHA试图从宕机的主服务器上保存二进制日志,最大程度的保证数据的不丢失 使用MySQL 5.5的半同步复制,可以大大降低数据丢失的风险 实验思路 1.MHA架构 (1)数据库安装 (2)一主两从 (3)MHA搭建 2.故障

    MySQL之MHA高可用配置及故障切换

    前言:跑相同服务的服务器组合起来称为群集中心化群集:有master.slave,MHA用来解决群集中master宕机的情况,MMM群集架构:有两台master服务器MHA概述 日本DeNA公司youshimaton(现就职于Facebook公司)开发 一套优秀的作为MySQL高可用性环境下故障切换和主从提升的高可用软件MHA的组成 MHA Manager(管理节点) MHA Node(数据节点)MHA特点 自动故障切换过程中,MHA试图从宕机的主服务器上保存二进制日志,最大程度的保证数据的不丢失

    玩转MHA高可用集群

    MHA高可用集群 =============================================================================== 概述:  本章将主要介绍MySQL中MHA高可用集群的相关内容,如下: MHA的功能介绍: MHA的集群架构,工作原理: CentOS 7上MHA实战配置部署及故障转移测试: =========================================================================

    MHA高可用群集

    MHA高可用集群 文章目录 一.MHA 简介:二.部署 MHA:第一步:三台主从服务器安装 mysql第二步:修改 mysql 的主配置文件:/etc/my.cnf ,注意三台服务器的 server-id 不能一样第三步:三台服务器启动 mysql 服务第四步:配置 Mysql 主从同步(一主两从)第五步:安装 MHA第六步:启动 MHA 一.MHA 简介: MHA(Master High Availability) (1)简介 目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeN

    MHA高可用集群

    MHA高可用集群 文章目录 一.MHA 简介:二.部署 MHA:第一步:三台主从服务器安装 mysql第二步:修改 mysql 的主配置文件:/etc/my.cnf ,注意三台服务器的 server-id 不能一样第三步:三台服务器启动 mysql 服务第四步:配置 Mysql 主从同步(一主两从)第五步:安装 MHA第六步:启动 MHA 一.MHA 简介: MHA(Master High Availability) (1)简介 目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeN

    搭建MySQL MHA高可用

    本文内容参考:http://www.ttlsa.com/mysql/step-one-by-one-deploy-mysql-mha-cluster/ MySQL MHA 高可用集群 环境: Linux: centos 6.6 MySQL: 5.5.49 MHA: mha4mysql-manager-0.56-0.el6.noarch.rpm(管理端) 以及 mha4mysql-node-0.56-0.el6.noarch.rpm(节点) 192.168.178.128 MySQL主从环境: M

    Mysql MHA高可用集群架构

    记得之前发过一篇文章,名字叫<浅析MySQL高可用架构>,之后一直有很多小伙伴在公众号后台或其它渠道问我,何时有相关的深入配置管理文章出来,因此,民工哥,也将对前面的各类架构逐一进行整理,然后发布出来.那么今天将来发布的MHA的架构整体规划与配置操作. 简单介绍MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,作为MySQL高可用性环境下故障切换和主从提升的高可用软件.在MySQL故障切换过程中,MHA能做到在0~30秒之内自动完成数

    专职DBA-基于MHA高可用搭建MySQL读写分离架构-Atlas

    专职DBA-基于MHA高可用搭建MySQL读写分离架构-Atlas 1.Atlas介绍 Atlas是由Qihoo360,Web平台部基础架构团队开发维护的一个基于MySQL协议的数据中间层项目. 它是在mysql-proxy-0.8.2版本的基础上,对其进行了优化,增加了一些新的功能特性. 360内部使用Atlas运行的mysql业务,每天承载的读写请求数达几十亿条. 下载地址:https://github.com/Qihoo360/Atlas/releases 注意: 1.Atlas只能安装运