MHA工作原理總結(jié)為以下幾條:
(1) 從宕機崩潰的 master 保存二進(jìn)制日志事件(binlog events);
(2) 識別含有最新更新的 slave ;
(3) 應(yīng)用差異的中繼日志(relay log) 到其他 slave ;
(4) 應(yīng)用從 master 保存的二進(jìn)制日志事件(binlog events);
(5) 通過Manager控制器提升一個 slave 為新 master ;
(6) 使用其他的 slave 連接新的 master 進(jìn)行復(fù)制。
準(zhǔn)備環(huán)境:
名稱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 |
進(jìn)行配置:
首先194-196安裝一下mysql
yum -y
install mariadb mariadb-server
進(jìn)行mysql-master配置
vim /etc/my.conf
server-id
=1 //復(fù)制集群中的各節(jié)點的id均必須唯一
log-bin
=mysql-bin //開啟二進(jìn)制日志
skip-name-resolve //關(guān)閉名稱解析(非必須)
relay-log
=mysql-relay //開啟中繼日志
systemctl restart mariadb
然后mysql-slave1配置
vim /etc/my.cnf
server-id
= 2 //復(fù)制集群中的各節(jié)點的id均必須唯一;
relay-log
= relay-log //開啟中繼日志
log-bin
=mysql-log //開啟二進(jìn)制日志
read_only
= ON //啟用只讀屬性(非必須)
relay_log_purge
= 0 //是否自動清空不再需要中繼日志(非必須)
skip_name_resolve //關(guān)閉名稱解析(非必須)
log_slave_updates
= 1 //使得更新的數(shù)據(jù)寫進(jìn)二進(jìn)制日志中
systemctl restart mariadb
接著mysql-slave2配置
vim /etc/my.cnf
server-id
= 3 //復(fù)制集群中的各節(jié)點的id均必須唯一;
relay-log
= relay-log //開啟中繼日志
log-bin
=mysql-log //開啟二進(jìn)制日志
read_only
= ON //啟用只讀屬性(非必須)
relay_log_purge
= 0 //是否自動清空不再需要中繼日志(非必須)
skip_name_resolve //關(guān)閉名稱解析(非必須)
log_slave_updates
= 1 //使得更新的數(shù)據(jù)寫進(jìn)二進(jìn)制日志中
systemctl restart mariadb
接下來配置mysql一主多從
mysql-master操作授權(quán)用戶
grant all on *.* to
'xiao'@
'10.0.0.%' identified by
'123';
flush privileges
;
show master status
;
mysql-slave1 slave2都進(jìn)行如下配置
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地址)
繼續(xù)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操作
進(jìn)行用戶授權(quán)
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 //每個遠(yuǎn)程主機的工作目錄在何處
ssh_user
=root // 基于ssh的密鑰認(rèn)證
repl_user
=xiao //數(shù)據(jù)庫用戶名
repl_password
=123 //數(shù)據(jù)庫密碼
ping_interval
=1 //ping間隔時長
[server1
] //節(jié)點1
hostname
=10.0.0.194 //節(jié)點1主機地址
ssh_port
=22 //節(jié)點1的ssh端口
candidate_master
=1 //將來可不可以成為master候選節(jié)點/主節(jié)點
[server2
]
hostname
=10.0.0.195 //節(jié)點2
ssh_port
=22
candidate_master
=1
[server3
]
hostname
=10.0.0.196 //節(jié)點3
ssh_port
=22
candidate_master
=1
對四個節(jié)點進(jìn)行檢測
檢測各節(jié)點間 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節(jié)點狀態(tài)
masterha_check_status -conf
=/etc/mha_master/mha.cnf
測試
停掉mysql-master并查看slave2狀態(tài)
這是模擬之前的主庫mysql 10.0.0194
mysql-master操作
systemctl stop mariadb
查看slave2狀態(tài)以成功切到了salve1為主庫
show slave status \G
;
總結(jié)
以上是生活随笔為你收集整理的部署MNA高可用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。