- 环境:
- 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可以相互登陆
-
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
-
二、主库配置
#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(备用主库)配置:

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

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即可!
|