MHA工作原理總結為以下幾條:
(1) 從宕機崩潰的 master 保存二進制日志事件(binlog events);
(2) 識別含有最新更新的 slave ;
(3) 應用差異的中繼日志(relay log) 到其他 slave ;
(4) 應用從 master 保存的二進制日志事件(binlog events);
(5) 通過Manager控制器提升一個 slave 為新 master ;
(6) 使用其他的 slave 連接新的 master 進行復制。
準備環境:
名稱IP
| mysql-master | 10.0.0.194 |
| mysql-slave1 | 10.0.0.195 |
| mysql-slave2 | 10.0.0.196 |
| mysql-mha | 10.0.0.193 |
進行配置:
首先194-196安裝一下mysql
yum -y
install mariadb mariadb-server
進行mysql-master配置
vim /etc/my.conf
server-id
=1 //復制集群中的各節點的id均必須唯一
log-bin
=mysql-bin //開啟二進制日志
skip-name-resolve //關閉名稱解析(非必須)
relay-log
=mysql-relay //開啟中繼日志
systemctl restart mariadb
然后mysql-slave1配置
vim /etc/my.cnf
server-id
= 2 //復制集群中的各節點的id均必須唯一;
relay-log
= relay-log //開啟中繼日志
log-bin
=mysql-log //開啟二進制日志
read_only
= ON //啟用只讀屬性(非必須)
relay_log_purge
= 0 //是否自動清空不再需要中繼日志(非必須)
skip_name_resolve //關閉名稱解析(非必須)
log_slave_updates
= 1 //使得更新的數據寫進二進制日志中
systemctl restart mariadb
接著mysql-slave2配置
vim /etc/my.cnf
server-id
= 3 //復制集群中的各節點的id均必須唯一;
relay-log
= relay-log //開啟中繼日志
log-bin
=mysql-log //開啟二進制日志
read_only
= ON //啟用只讀屬性(非必須)
relay_log_purge
= 0 //是否自動清空不再需要中繼日志(非必須)
skip_name_resolve //關閉名稱解析(非必須)
log_slave_updates
= 1 //使得更新的數據寫進二進制日志中
systemctl restart mariadb
接下來配置mysql一主多從
mysql-master操作授權用戶
grant all on *.* to
'xiao'@
'10.0.0.%' identified by
'123';
flush privileges
;
show master status
;
mysql-slave1 slave2都進行如下配置
change master to master_host
='10.0.0.194',
master_user
='xiao',
master_password
='123',
master_log_file
='mysql-bin.000002',
master_log_pos
=245
;
start slave
;
show slave status\G
;
接下來生成免密交互 四臺都要互通
ssh-keygen -t rsa
ssh-copy-id IP (其他三臺的IP地址)
繼續MHA部署安裝
點擊下載rpm包
MHA都安裝
master master和slave 1 2 安裝node版
yum -y localinstall mha4mysql-manager-0.56-0.el6.noarch.rpm
yum -y localinstall mha4mysql-node-0.56-0.el6.noarch.rpm
msyql-master操作
進行用戶授權
grant all on *.* to
'wtc'@
'%' identified by
'123';
MNA操作
定義 MHA 管理配置文件
mkdir /etc/mha_master
vim /etc/mha_master/mha.cnf
[server default
] //適用于server1,2,3個server的配置
user
=wtc //mha管理用戶
password
=123 //mha管理密碼
manager_workdir
=/etc/mha_master/app1 //mha_master自己的工作路徑
manager_log
=/etc/mha_master/manager.log // mha_master自己的日志文件
remote_workdir
=/mydata/mha_master/app1 //每個遠程主機的工作目錄在何處
ssh_user
=root // 基于ssh的密鑰認證
repl_user
=xiao //數據庫用戶名
repl_password
=123 //數據庫密碼
ping_interval
=1 //ping間隔時長
[server1
] //節點1
hostname
=10.0.0.194 //節點1主機地址
ssh_port
=22 //節點1的ssh端口
candidate_master
=1 //將來可不可以成為master候選節點/主節點
[server2
]
hostname
=10.0.0.195 //節點2
ssh_port
=22
candidate_master
=1
[server3
]
hostname
=10.0.0.196 //節點3
ssh_port
=22
candidate_master
=1
對四個節點進行檢測
檢測各節點間 ssh 互信通信配置是否 ok
MHA操作
masterha_check_ssh -conf
=/etc/mha_master/mha.cnf
啟動MHA
nohup masterha_manager -conf
=/etc/mha_master/mha.cnf
&> /etc/mha_master/manager.log
&
查看mater節點狀態
masterha_check_status -conf
=/etc/mha_master/mha.cnf
測試
停掉mysql-master并查看slave2狀態
這是模擬之前的主庫mysql 10.0.0194
mysql-master操作
systemctl stop mariadb
查看slave2狀態以成功切到了salve1為主庫
show slave status \G
;
總結
以上是生活随笔為你收集整理的部署MNA高可用的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。