1. 程式人生 > >Mysql MHA高可用集群架構

Mysql MHA高可用集群架構

mysql- root 免密鑰登錄 sep ges 至少 isp 原來 mysql數據庫

記得之前發過一篇文章,名字叫《淺析MySQL高可用架構》,之後一直有很多小夥伴在公眾號後臺或其它渠道問我,何時有相關的深入配置管理文章出來,因此,民工哥,也將對前面的各類架構逐一進行整理,然後發布出來。那麽今天將來發布的MHA的架構整體規劃與配置操作。

簡單介紹
MHA(Master High Availability)目前在MySQL高可用方面是一個相對成熟的解決方案,作為MySQL高可用性環境下故障切換和主從提升的高可用軟件。在MySQL故障切換過程中,MHA能做到在0~30秒之內自動完成數據庫的故障切換操作,並且在進行故障切換的過程中,MHA能在最大程度上保證數據的一致性,以達到真正意義上的高可用。

MHA由兩部分組成:MHA Manager(管理節點)和MHA Node(數據節點)。MHA Manager可以單獨部署在一臺獨立的機器上管理多個master-slave集群,也可以部署在一臺slave節點上。MHA Node運行在每臺MySQL服務器上,MHA Manager會定時探測集群中的master節點,當master出現故障時,它可以自動將最新數據的slave提升為新的master,然後將所有其他的slave重新指向新的master。整個故障轉移過程對應用程序完全透明。
目前MHA主要支持一主多從的架構,要搭建MHA,要求一個復制集群中必須最少有三臺數據庫服務器,一主二從,即一臺充當master,一臺充當備用master,另外一臺充當從庫,因為至少需要三臺服務器

布署規劃
系統信息

[root@db250 ~]# cat /etc/redhat-release
CentOS release 6.8 (Final)
[root@db250 ~]# uname -r
2.6.32-642.el6.x86_64

數據庫
mysql57-community-release-el6-9.noarch.rpm
環境規劃
Db250 集群管理節點 192.168.4.250
Db251 主庫 192.168.4.251
Db253 從庫(備主庫) 192.168.4.253
Db254 從庫 192.168.4.254
架構圖如下
技術分享圖片

配置SSH免密登陸與hosts文件


配置hosts文件

cat>>/etc/hosts<<EOF
192.168.4.250 db250
192.168.4.251 db251
192.168.4.253 db253
192.168.4.254 db254
EOF

配置完成後檢查下

[root@db254 ~]# tail -4 /etc/hosts
192.168.4.250 db250
192.168.4.251 db251
192.168.4.253 db253
192.168.4.254 db254

配置SSH免密鑰登陸

ssh-keygen -t rsa
ssh-copy-id 192.168.4.251
ssh-copy-id 192.168.4.253
ssh-copy-id 192.168.4.254

技術分享圖片
--------------以上配置所有服務器都需要配置----------------

安裝mysql與配置主從同步
安裝mysql數據庫服務

rpm -ivh mysql57-community-release-el6-9.noarch.rpm
yum install mysql-community-server -y
/etc/init.d/mysqld start

默認密碼是在

[root@db254 ~]# grep ‘temporary password‘ /var/log/mysqld.log
2017-08-30T08:08:05.956867Z 1 [Note] A temporary password is generated for root@localhost: f;2YK51qXlo/

修改下默認密碼吧,為了後面方便操作

mysql> alter user ‘root‘@‘localhost‘ identified by ‘123456‘;

--------------以上配置三臺數據庫服務器都需要配置----------------

配置主從同步
Db251與db253的配置文件都需要配置開啟binlog
server_id=251
log_bin=master-bin
log_bin_index=master-bin.index

server_id=253
log_bin=slave-bin
log_bin_index=slave-bin.index
log-slave-updates
relay_log_index=slave-relay-bin.index
relay_log=slave-relay-bin

server_id=254
relay_log_index=slave-relay-bin.index
relay_log=slave-relay-bin

同步主庫數據到從庫,主從同步操作請參考之前的文章
檢查主從同步狀態
mysql -uroot -p123456 -e "show slave status\G" |egrep "Slave_IO_Running|Slave_SQL_Running"
技術分享圖片
所有數據庫節點配置MHA管理用戶與權限
grant all on . to mha@‘192.168.4.%‘ identified by ‘123456‘;
至此所有基礎環境組建完成

安裝配置MHA
https://downloads.mariadb.com/MHA/ 下載地址
整個MHA服務安裝過程如下:

安裝依賴包

yum install perl-DBD-MySQL perl-Config-Tiny perl-Log-Dispatch -y 
yum install perl-Parallel-ForkManager perl-Time-HiRes –y

管理節點安裝

rpm -ivh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
yum localinstall -y mha4mysql-manager-0.52-0.noarch.rpm
yum localinstall -y mha4mysql-node-0.52-0.noarch.rpm

其它節點安裝
yum localinstall -y mha4mysql-node-0.52-0.noarch.rpm
安裝過程中可能會報錯,根據提示去解決

配置過程如下:

Mkdir /mha
[root@db250 ~]# vim /etc/masterha_default.cnf
[server default]
#剛才授權的mysql管理用戶名
user=mha
password=123456
manager_workdir=/mha
manager_log=/mha/manager.log
remote_workdir=/mha

#ssh免密鑰登錄的帳號名
ssh_user=root
#mysql復制帳號,用來在主從機之間同步二進制日誌等
repl_user=slave
repl_password=123456

#ping間隔,用來檢測master是否正常
ping_interval= 1

[server1]
hostname=db251
master_binlog_dir=/var/lib/mysql
#候選master掛掉時候優先讓它頂
candidate_master=1

[server2]
hostname=db253
master_binlog_dir=/var/lib/mysql/
candidate_master=1

[server3]
hostname=db254
master_binlog_dir=/var/lib/mysql/
no_master=1
#不能成為master

技術分享圖片

masterha_check_ssh 檢查MHA的SSH配置狀況
masterha_check_repl 檢查MySQL復制狀況
masterha_manger 啟動MHA
masterha_check_status 檢測當前MHA運行狀態
masterha_master_monitor 檢測master是否宕機
masterha_master_switch 控制故障轉移(自動或者手動)
masterha_conf_host 添加或刪除配置的server信息

驗證操作

[root@db250 ~]# masterha_check_ssh --conf=/etc/masterha_default.cnf
檢查主從同步
masterha_check_repl --conf=/etc/masterha_default.cnf

技術分享圖片
技術分享圖片

啟動MHA服務

[root@db250 ~]# masterha_manager --conf=/etc/masterha_default.cnf &
[1] 2035
[root@db250 ~]# Fri Sep  1 01:52:25 2017 - [info] Reading default configuratoins from /etc/masterha_default.cnf..
Fri Sep  1 01:52:25 2017 - [info] Reading application default configurations from /etc/masterha_default.cnf..
Fri Sep  1 01:52:25 2017 - [info] Reading server configurations from /etc/masterha_default.cnf..

查看啟動日誌
技術分享圖片
技術分享圖片
好吧,到此MHA高可用總算成功了,也算可以的哈!

接下來模擬下故障,將db251關閉

[root@db251 ~]# /etc/init.d/mysqld stop
Stopping mysqld:              [  OK  ]

查看日誌
技術分享圖片
技術分享圖片
技術分享圖片
技術分享圖片
技術分享圖片
發現新的主庫已切換到db253這臺服務器上了,接下來查看下主從同步的情況
技術分享圖片

技術分享圖片
當原來的主服務器故障修復後,需要手工將原主變成從

[root@db250 ~]# grep -i "All other slaves should start" /mha/manager.log
Fri Sep  1 01:59:05 2017 - [info]  All other slaves should start replication from here. Statement should be: CHANGE MASTER TO MASTER_HOST=‘db253 or 192.168.4.253‘, MASTER_PORT=3306, MASTER_LOG_FILE=‘slave-bin.000003‘, MASTER_LOG_POS=760546, MASTER_USER=‘slave‘, MASTER_PASSWORD=‘xxx‘;

因此此時我在原主庫上執行操作將修復的主庫改為從庫
技術分享圖片

技術分享圖片
技術分享圖片
接下來在新的主庫上寫入數據來測試同步情況

技術分享圖片

技術分享圖片

技術分享圖片

Mysql MHA高可用集群架構