Mysql实现MHA高可用
admin
2023-05-01 13:43:45
0
  • 环境:
    • CentOS7.4 x 4
    • mha4mysql-manager x 1
    • mha4mysql-node x 3
    • node节点搭建一主双从
    • mha4mysql代码托管:https://code.google.com/archive/p/mysql-master-ha/

  • 一、配置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

      Mysql实现MHA高可用

    • (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

      Mysql实现MHA高可用

    • (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';  
    

    Mysql实现MHA高可用

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

    • (1)修改配置文件
      [mysqld]
      server_id=2             #备用主库需要启用二进制日志!!!
      log-bin                 #备用主库需要启用二进制日志!!!
      read_only               #备用主库需要启用二进制日志!!!
      relay_log_purge=0
      skip_name_resolve=1     #禁止名字解析
      innodb_file_per_table

    Mysql实现MHA高可用

    • (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;

      Mysql实现MHA高可用

  • 四、从库2配置:

    • (1)修改配置文件
      [mysqld]
      server_id=3
      read_only
      relay_log_purge=0
      skip_name_resolve=1     #禁止名字解析
      innodb_file_per_table

      Mysql实现MHA高可用

    • (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;

      Mysql实现MHA高可用

  • 五、检查并启用MHA

    • (1)检查SSH连接
      masterha_check_ssh --conf=/etc/mastermha/app1.cnf 

    Mysql实现MHA高可用

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

    Mysql实现MHA高可用

  • (3)启动脚本,当检测到主库无法连接就会退出,并提升从库为主库。

    masterha_manager --conf=/etc/mastermha/app1.cnf             
    
  • 错误日志:/data/mastermha/app1/manager.log
  • 当MHA短时间内频繁的切换主库时,可能会报错,删除/data/mastermha/app1/app1.failover.complete即可!

相关内容

热门资讯

美媒又想起这茬:2年前在地中海... 【文/观察者网 阮佳琪】2024年12月23日,载有16名船员的俄罗斯“大熊星座”号货船在西班牙近海...
App过度索取授权或被境外间谍... 微信公众号“国家安全部”5月13日发文: 手机里各种各样的应用程序(APP)五花八门,在方便我们生...
广合科技获得发明专利授权:“一... 证券之星消息,根据天眼查APP数据显示广合科技(001389)新获得一项发明专利授权,专利名为“一种...
华尔街科技老将:大科技公司分化... 5月11日,互联网泡沫时期的知名芯片分析师、Niles Investment Management创...
香港80后“地产女王”烧炭身亡... 据《香港01》报道,5月12日,香港九龙传统豪宅地段加多利山畔的豪宅项目Kadoorie Hill发...
谷歌发布安卓 AI 系统,这就... 和去年一样,在正式的 Google I/O 开发者大会之前,谷歌为 Android 单独开了一次小型...
300斤医生走红 曾一年猛涨1...   300斤医生走红 曾一年猛涨100斤  【300斤医生走红 曾一年猛涨100斤】5月11日,上海...
新乡市主要负责同志职务调整 日前,中共河南省委决定:魏建平同志任中共新乡市委书记,李卫东同志不再担任中共新乡市委书记、常委、委员...
九阳电饭锅H01故障 H01是因为上盖异常高温,有可能是机板不良造成的;同时也可能是故障前没有清洗上盖或溢出米浆等情况造成...
电饭煲显示e3是什么原因 1、可能是电饭煲里面的食物水分烧干之后,密封圈在高温运转的环境下被烧焦了,这个情况下可能会出现故障提...