#使用在线yum源安装
yum install epel-release --nogpgcheck -y
yum install -y perl-DBD-MySQL \
perl-Config-Tiny \
perl-Log-Dispatch \
perl-Parallel-ForkManager \
perl-ExtUtils-CBuilder \
perl-ExtUtils-MakeMaker \
perl-CPAN
5.2安装 MHA 软件包,先在所有服务器上必须先安装 node 组件对于每个操作系统版本不一样,这里 CentOS7.4 必须选择 0.57 版本。
在所有服务器上必须先安装 node 组件,最后在 MHA-manager 节点上安装 manager 组件,因为 manager 依赖 node 组件。
cd /opt
tar zxvf mha4mysql-node-0.57.tar.gz
cd mha4mysql-node-0.57
perl Makefile.PL
make && make install
5.3在 MHA manager 节点上安装 manager 组件cd /opt
tar zxvf mha4mysql-manager-0.57.tar.gz
cd mha4mysql-manager-0.57
perl Makefile.PL
make && make install
#manager 组件安装后在/usr/local/bin 下面会生成几个工具,主要包括以下几个:
masterha_check_ssh 检查 MHA 的 SSH 配置状况
masterha_check_repl 检查 MySQL 复制状况
masterha_manger 启动manager的脚本
masterha_check_status 检测当前 MHA 运行状态
masterha_master_monitor 检测 master 是否宕机
masterha_master_switch 控制故障转移(自动或者手动)
masterha_conf_host 添加或删除配置的 server 信息
masterha_stop 关闭manager
#node 组件安装后也会在/usr/local/bin 下面会生成几个脚本(这些工具通常由 MHAManager 的脚本触发,无需人为操作)主要如下:
save_binary_logs 保存和复制 master 的二进制日志
apply_diff_relay_logs 识别差异的中继日志事件并将其差异的事件应用于其他的 slave
filter_mysqlbinlog 去除不必要的 ROLLBACK 事件(MHA 已不再使用这个工具)
purge_relay_logs 清除中继日志(不会阻塞 SQL 线程)
6.在所有服务器上配置无密码认证##可实现远程登录未知主机名时,不需要输入yes
vim /etc/ssh/ssh_config
#将35行取消注释,并将 ask 修改为 no
StrictHostKeyChecking no
yum -y install sshpass
ssh-keygen -t rsa
sshpass -p '123456' ssh-copy-id 192.168.88.20 #实现免交互远程登录
6.1在 manager 节点上配置到所有数据库节点的无密码认证ssh-keygen -t rsa #一路按回车键
ssh-copy-id 192.168.88.10
ssh-copy-id 192.168.88.20
ssh-copy-id 192.168.88.30
ssh-copy-id 命令可以把本地主机的公钥复制到远程主机的 authorized_keys 文件上。
authorized_keys 文件用来验证 client 。
使用 ssh-copy-id 命令将本地公钥复制到远程主机之后可以实现免密登录远程主机。
ssh-copy-id 用来将本地公钥复制到远程主机。
如果不传入 -i 参数,ssh-copy-id 使用默认 ~/.ssh/identity.pub 作为默认公钥。
如果多次运行 ssh-copy-id ,该命令不会检查重复,会在远程主机中多次写入 authorized_keys 。