MySQL集羣高可用架構之MHA

前面寫過一篇:淺談MySQL集羣高可用架構。以後一直有不少小夥伴在後臺或其它渠道問我,什麼時候有相關的深刻配置管理文章出來,所以,民工哥,也將對前面的各種架構逐一進行整理,而後發佈出來。那麼今天未來發布的MHA的架構總體規劃與配置操做。node

一、架構簡介

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

該軟件由兩部分組成:MHA Manager(管理節點)和MHA Node(數據節點)。MHA Manager能夠單獨部署在一臺獨立的機器上管理多個master-slave集羣,也能夠部署在一臺slave節點上。MHA Node運行在每臺MySQL服務器上,MHA Manager會定時探測集羣中的master節點,當master出現故障時,它能夠自動將最新數據的slave提高爲新的master,而後將全部其餘的slave從新指向新的master。整個故障轉移過程對應用程序徹底透明。面試

目前MHA主要支持一主多從的架構,要搭建MHA,要求一個複製集羣中必須最少有三臺數據庫服務器,一主二從,即一臺充當master,一臺充當備用master,另一臺充當從庫,由於至少須要三臺服務器。redis

二、佈署規劃

系統信息sql

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

數據庫版本數據庫

mysql-5.7.17

環境規劃vim

Db250    集羣管理節點 192.168.4.250
Db251    主庫  192.168.4.251
Db253    從庫(備主庫) 192.168.4.253
Db254    從庫 192.168.4.254

架構圖以下
segmentfault

三、配置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免密鑰登錄

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與配置主從同步

同步主庫數據到從庫,主從同步操做請參考以前的文章

Linux系統MySQL數據庫主從同步實戰過程

檢查主從同步狀態

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服務安裝過程以下:

安裝依賴包

yum install perl-DBD-MySQL perl-Config-Tiny perl-Log-Dispatch 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

安裝過程當中可能會報錯,根據提示去解決

配置過程以下:

[root@db250 ~]# 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信息

檢測SSH免密登陸

檢測同步

七、啓動MHA服務

[root@db250 ~]# masterha_manager --conf=/etc/masterha_default.cnf &

[1] 2035Fri 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..

查看啓動日誌

從啓動日誌也能夠看出目前的DBmaster是DB251這臺服務器,說明啓動成功。

八、測試故障自動切換

接下來模擬下故障,將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 replicationfrom here. Statement should be: CHANGE MASTER TO MASTER_HOST='db253 or192.168.4.253', MASTER_PORT=3306,MASTER_LOG_FILE='slave-bin.000003',MASTER_LOG_POS=760546, MASTER_USER='slave', MASTER_PASSWORD='xxx';

發現原來的主庫修復上線後成爲了新的從庫,而後同DB253進行同步

測試主寫同步狀況

同步正常

點擊-->民工哥技術之路 關注微信公衆號,對話框回覆關鍵字:1024 能夠獲取一份最新整理的 2048G 技術乾貨:包括系統運維、數據庫、redis、MogoDB、電子書、Java基礎課程、Java實戰項目、架構師綜合教程、架構師實戰項目、大數據、Docker容器、ELK Stack、機器學習、BAT面試精講視頻等。

相關文章
相關標籤/搜索