mysql集群MHA方式部署

1. 基本信息

部署機器角色部署路徑
192.168.242.71MySQL-Mater + MHA-NodeMySQL: /alidata1/mysql-5.7.43
192.168.242.72MySQL-Slave + MHA-NodeMHA-Node: /alidata1/admin/tools/mha4mysql-node-0.58
192.168.242.73MySQL-Slave + MHA-Node
192.168.242.74MHA-ManagerMHA-Manager: /alidata1/admin/tools/mha4mysql-manager-0.58
192.168.242.100VIP

2. 簡介

## 簡介
MHA(Master HA) 是一款開源的 MySQL 的高可用程序,它為 MySQL主從復制架構提供了自動化主故障轉移功能.
MHA 在監控到 master 節點故障時,會提升其中擁有最新數據的 slave 節點成為新的master節點, 在此期間,MHA 會通過于其它從節點獲取額外信息來避免一致性方面的問題.
MHA 還提供了 master 節點的在線切換功能,即按需切換 master/slave 節點.
MHA 能夠在30秒內實現故障切換,并能在故障切換中,最大可能的保證數據一致性.## 原理
(1) 獲取從宕機崩潰的 master 保存二進制日志事件(binlog events)
(2) 識別含有最新更新的 slave
(3) 將差異的中繼日志(relay log)應用到其他 slave
(4) 將 master 保存的二進制日志事件(binlog events)應用到要提升為master節點的slave
(5) 將這 slave 只讀模式解除并提升為新 master, 重新部署主從關系

3. 安裝MHA

3.1 提前操作
## 1.  安裝mysql主從 -- 略
## MHA-0.58 支持GTID ,只要保證MySQL主從關系正常即可## 2. 所有機器兩兩之間ssh免密
## (1) 在任意一臺機器使用root用戶執行命令ssh-keygen生成公秘鑰(如 192.168.242.71), 然后ssh-copy-id到所有機器(192.168.242.71/72/73/74)
## (2) 將此機器的公秘鑰scp到所有機器(192.168.242.71/72/73/74)## 2. MySQL-Master主機配置虛擬ip -- 192.168.242.71
# /sbin/ifconfig ens33:1 192.168.242.100/24
3.2 安裝MHA-Node
## 1.將安裝包上傳到所有機器, 包括MHA-Manager機器 (192.168.242.71/72/73/74)
# pwd
/alidata1/admin/tools/
# tar xf mha4mysql-node-0.58.tar.gz## 2.編譯
# cd mha4mysql-node-0.58
# yum install -y make gcc perl-DBD-MySQL perl-Config-Tiny perl-Log-Dispatch perl-Parallel-ForkManager perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker perl-CPAN
# perl Makefile.PL
# make && make install
3.3 安裝MHA-Manager
## 1.將安裝包上傳MHA-Manager機器 (192.168.242.74)
# pwd
/alidata1/admin/tools/
# tar xf mha4mysql-manager-0.58.tar.gz## 2.編譯
# cd mha4mysql-manager-0.58
# yum install -y make gcc perl-DBD-MySQL perl-Config-Tiny perl-Log-Dispatch perl-Parallel-ForkManager perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker perl-CPAN
# perl Makefile.PL
# make && make install## 3.拷貝可執行文件到/usr/local/bin
# chmod +x  samples/scripts/*
# cp samples/scripts/* /usr/local/bin/## 4. 修改可執行文件 /usr/local/bin/master_ip_failover, 內容如下
#!/usr/bin/env perl
use strict;
use warnings FATAL => 'all';use Getopt::Long;my (
$command, $ssh_user, $orig_master_host, $orig_master_ip,
$orig_master_port, $new_master_host, $new_master_ip, $new_master_port
);
#############################添加內容部分#########################################
my $vip = '192.168.242.100'; ## 指定vip的地址 192.168.242.100
my $brdc = '192.168.242.255';    ## 指定vip的廣播地址 192.168.242.255
my $ifdev = 'ens33';             ## 指定vip綁定的網卡 ens33
my $key = '1';                   ## 指定vip綁定的虛擬網卡序列號
my $ssh_start_vip = "sudo /sbin/ifconfig ens33:$key $vip"; ## 代表此變量值為ifconfig ens33:1 192.168.242.100
my $ssh_stop_vip = "sudo /sbin/ifconfig ens33:$key down";  ## 代表此變量值為ifconfig ens33:1 192.168.242.100 down
my $exit_code = 0;               ## 指定退出狀態碼為0#my $ssh_start_vip = "/usr/sbin/ip addr add $vip/24 brd $brdc dev $ifdev label $ifdev:$key;/usr/sbin/arping -q -A -c 1 -I $ifdev $vip;iptables -F;";
#my $ssh_stop_vip = "/usr/sbin/ip addr del $vip/24 dev $ifdev label $ifdev:$key";##################################################################################
GetOptions(
'command=s' => \$command,
'ssh_user=s' => \$ssh_user,
'orig_master_host=s' => \$orig_master_host,
'orig_master_ip=s' => \$orig_master_ip,
'orig_master_port=i' => \$orig_master_port,
'new_master_host=s' => \$new_master_host,
'new_master_ip=s' => \$new_master_ip,
'new_master_port=i' => \$new_master_port,
);exit &main();sub main {print "\n\nIN SCRIPT TEST====$ssh_stop_vip==$ssh_start_vip===\n\n";if ( $command eq "stop" || $command eq "stopssh" ) {my $exit_code = 1;
eval {
print "Disabling the VIP on old master: $orig_master_host \n";
&stop_vip();
$exit_code = 0;
};
if ($@) {
warn "Got Error: $@\n";
exit $exit_code;
}
exit $exit_code;
}
elsif ( $command eq "start" ) {my $exit_code = 10;
eval {
print "Enabling the VIP - $vip on the new master - $new_master_host \n";
&start_vip();
$exit_code = 0;
};
if ($@) {
warn $@;
exit $exit_code;
}
exit $exit_code;
}
elsif ( $command eq "status" ) {
print "Checking the Status of the script.. OK \n";
exit 0;
}
else {
&usage();
exit 1;
}
}
sub start_vip() {
`ssh root\@$new_master_host \" $ssh_start_vip \"`;   ## 直接寫死root 否則主從切換時報錯 ssh_user 沒有初始化
}
## A simple system call that disable the VIP on the old_master
sub stop_vip() {
`ssh root\@$orig_master_host \" $ssh_stop_vip \"`;   ## 直接寫死root 否則主從切換時報錯 ssh_user 沒有初始化
}sub usage {
print
"Usage: master_ip_failover --command=start|stop|stopssh|status --orig_master_host=host --orig_master_ip=ip --orig_master_port=port --new_master_host=host --new_master_ip=ip --new_master_port=port\n";
}## 5.新建配置文件
# vim /alidata1/admin/tools/mysql_mha.conf
[server default]
## 指定manager日志路徑
manager_log=/alidata1/admin/logs/mha4mysql/manager.log
## 指定manager工作目錄
manager_workdir=/alidata1/admin/tools/mha4mysql-manager-0.58
## 指定mha在遠程節點上的工作目錄
remote_workdir=/alidata1/admin/tools/mha4mysql-manager-0.58
## 指定master保存binlog的位置,這里的路徑要與master里配置的binlog的路徑一致,以便MHA能找到
master_binlog_dir=/alidata1/mysql-5.7.43/binlog
## 設置監控主庫,發送ping包的時間間隔,默認是3秒,嘗試三次沒有回應的時候自動進行failover
ping_interval=1
## 設置自動failover時候的切換腳本
master_ip_failover_script=/usr/local/bin/master_ip_failover
user=admin
password=Mysql_Admin_wMMpb8ks9
repl_user=repl
repl_password=Mysql_Repl_oOev7cU4h
port=3306
secondary_check_script=/usr/local/bin/masterha_secondary_check -s 192.168.242.72 -s 192.168.242.73
ssh_user=root[server1]
hostname=192.168.242.71
port=3306
ssh_user=root[server2]
hostname=192.168.242.72
port=3306
ssh_user=root
# candidate_master=1  ## 設置為候選master,設置該參數以后,發生主從切換以后將會將此從庫提升為主庫,即使這個從庫不是集群中最新的slave
# check_repl_delay=0  ## 默認情況下如果一個slave落后master 超過100M的relay logs的話 ## MHA將不會選擇該slave作為一個新的master, 因為對于這個slave的恢復需要花費很長時間## 通過設置check_repl_delay=0 MHA觸發切換在選擇一個新的master的時候將會忽略復制延時, ## 這個參數對于設置了candidate_master=1的主機非常有用,因為這個候選主在切換的過程中一定是新的master[server3]
hostname=192.168.242.73
port=3306
ssh_user=root## 5.啟動MHA-Manager
## --remove_dead_master_conf: 當成功failover后,MHA manager將會自動刪除配置文件中關于dead master的配置選項
## --ignore_last_failover: 如果最近failover 失敗,MHA 將不會再次開啟failover機制,因為這個問題可能再次發生。## 常規步驟:手動清理failover 錯誤文件,此文件一般在manager_workdir/app_name.failover.error文件,然后在啟動failover機制。## 如果設置此參數,MHA 將會繼續failover 不管上次的failover狀態。
# nohup masterha_manager --conf=/alidata1/admin/tools/mha4mysql-manager-0.58/mysql_mha.conf --remove_dead_master_conf --ignore_last_failover > /alidata1/admin/logs/mha4mysql/mha_manager.log < /dev/null 2>&1 &## 6. 常用命令 -- MHA-Manager機器執行
## (1) 測試 ssh 連通性
# masterha_check_ssh --conf=/alidata1/admin/tools/mha4mysql-manager-0.58/mysql_mha.conf 
## (2) 測試 mysql 主從連接情況
# masterha_check_repl -conf=/alidata1/admin/tools/mha4mysql-manager-0.58/mysql_mha.conf 
## (3) 查看狀態
# masterha_check_status --conf=/alidata1/admin/tools/mha4mysql-manager-0.58/mysql_mha.conf
## (4) 停止
## masterha_stop --conf=/alidata1/admin/tools/mha4mysql-manager-0.58/mysql_mha.conf

4. 模擬MySQL-Master 宕機

## 1. 使用命令行先初始化一些數據
# ./bin/mysql -h192.168.242.100 --port=3306 --user=admin -p'Mysql_Admin_wMMpb8ks9'
mysql> create database db_test;
mysql> create table db_test.t_test (   `id` int NOT NULL AUTO_INCREMENT,   `name` varchar(255) DEFAULT NULL,   PRIMARY KEY (`id`) );# for i in `seq 1 2500`; do ./bin/mysql -h192.168.242.100 -uadmin -p'Mysql_Admin_wMMpb8ks9' -e "insert into db_test.t_test(id, name) values($i,$i);"; done## 2. 停止MySQL-master
# systemctl stop mysqld    ## 192.168.242.71上操作##  大約15s后 虛擬ip 192.168.242.100會轉移到192.168.242.72上 
## 在192.168.242.73上執行 show slave status\G 會發現主節點已變成192.168.242.72
## 同時 MHA-Manager 進程會停止
## 從日志/alidata1/admin/logs/mha4mysql/mha_manager.log 可以看到  15:34:35發現主節點不可用  15:34:51遷移完成

5.原來主節點恢復到MHA集群中

## 1. 新的主節點上增加一些數據 -- 模擬驗證
# for i in `seq 2501 5000`; do ./bin/mysql -h192.168.242.100 -uadmin -p'Mysql_Admin_wMMpb8ks9' -e "insert into db_test.t_test(id, name) values($i,$i);"; done## 2.將舊主(192.168.242.71) 配置成新主(192.168.242.72)的從節點
## 2.1 修改新主(192.168.242.72)配置, 注釋掉 read_only = on## 2.2 修改配置 /etc/my.cnf   [mysqld] 下新增配置
log_slave_updates = 1   ## 從庫會將自己執行的事務寫入到從庫的二進制日志中   主主模式需要## 這樣做的目的是為了保證主從復制鏈路的完整性和一致性 以便其他從庫可以正確地復制從庫上執行的事務## A >> B >> C
read_only = on
relay_log = /alidata1/mysql-5.7.43/logs/relay.log
relay_log_purge = on
relay_log_recovery = on## 2.3 啟動舊主(192.168.242.71)上的musql
# systemctl restart mysqld ## 2.4 新主(192.168.242.72,)上備份數據 并恢復到舊主(192.168.242.71)
# mysqldump -uroot -p'Mysql_Root_lj11tLZgs' --single-transaction --set-gtid-purged=ON -A -B > all.sql  ## 備份 192.168.242.72執行
## 數據恢復到 192.168.242.71
# mysql -uroot -p'Mysql_Root_lj11tLZgs' -e 'reset master;'  
# mysql -uroot -p'Mysql_Root_lj11tLZgs' < all.sql## 2.5 配置主從 -- 192.168.242.71 操作
mysql > stop slave;
mysql > CHANGE MASTER TO MASTER_HOST='192.168.242.72',MASTER_USER='repl',MASTER_PASSWORD='Mysql_Repl_oOev7cU4h',MASTER_PORT=3306,MASTER_AUTO_POSITION=1;
mysql > start slave;
mysql > show slave status\G;## 3. 修改MHA-Manager配置并啟動  -- 192.168.242.74
# pwd
/alidata1/admin/tools/mha4mysql-manager-0.58
#  rm -rf mysql_mha.failover.complete
# vim mysql_mha.conf
...
secondary_check_script=/usr/local/bin/masterha_secondary_check -s 192.168.242.71 -s 192.168.242.73
...[server1]
hostname=192.168.242.71
port=3306
ssh_user=root# nohup masterha_manager --conf=/alidata1/admin/tools/mha4mysql-manager-0.58/mysql_mha.conf --remove_dead_master_conf --ignore_last_failover > /alidata1/admin/logs/mha4mysql/mha_manager.log < /dev/null 2>&1 &## 至此MHA集群已經恢復, 此時將192.168.242.72上mysql關閉后,VIP會再次漂移,表示集群狀態正常

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/62527.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/62527.shtml
英文地址,請注明出處:http://en.pswp.cn/web/62527.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【C++】8___繼承

目錄 一、基本語法 二、繼承方式 三、對象模型 四、繼承中的構造與析構的順序 五、繼承中同名成員處理 六、多繼承語法 七、菱形繼承 一、基本語法 好處&#xff1a;減少重復的代碼 語法&#xff1a; class 子類 &#xff1a; 繼承方式 父類 子類 也稱為 派生類 父類…

Netty客戶端接收不到服務端發送的數據問題

文章目錄 前言問題描述相關代碼解決方法 前言 環境 JDK&#xff1a;64位 jdk1.8.0_201 Netty&#xff1a;4.1.39.Final 問題描述 項目中使用Netty接受客戶端的消息&#xff0c;客戶端為硬件設備&#xff0c;在接受數據后發送數據到服務端。 同時因為客戶端沒有聯網&#xff…

IDEA方法注釋模板設置

目錄 創建模板 新建模板&#xff1a;命名為* 設置模板內容-IDEA格式模板 設置模板應用場景 設置參數 創建模板 /**Enter這里我們也按照這種習慣來設置IDEA的方法注釋&#xff1a;File-->Settings-->Editor-->Live Templates 先新建模板組&#xff0c;然后在模板組中…

vscode 配置C/C++環境控制臺參數

您可以通過以下步驟在VS Code中配置C/C環境的控制臺參數&#xff1a; 1&#xff0c;打開VS Code并進入您的C/C項目 2&#xff0c;點擊左側的"調試"圖標&#xff0c;然后點擊頂部的齒輪圖標&#xff0c;選擇“launch.json”。 3&#xff0c;在"launch.json&qu…

深度學習筆記之BERT(五)TinyBERT

深度學習筆記之TinyBERT 引言回顧&#xff1a;DistilBERT模型TinyBERT模型結構TinyBERT模型策略Transformer層蒸餾嵌入層蒸餾預測層蒸餾 TinyBERT模型的訓練效果展示 引言 上一節介紹了 DistilBERT \text{DistilBERT} DistilBERT模型&#xff0c;本節將繼續介紹優化性更強的知…

正則表達式——參考視頻B站《奇樂編程學院》

智能指針 一、背景&#x1f388;1.1. 模式匹配&#x1f388;1.2. 文本替換&#x1f388;1.3. 數據驗證&#x1f388;1.4. 信息提取&#x1f388;1.5. 拆分字符串&#x1f388;1.6. 高級搜索功能 二、原料2.1 參考視頻2.2 驗證網址 三、用法3.1 限定符3.1.1 ?3.1.2 *3.1.3 3.1.…

appium學習之二:adb命令

1、查看設備 adb devices 2、連接 adb connect IP:端口 3、安裝 adb install xxx.apk 4、卸載 adb uninstall 【包名】 5、把對應目錄下的1.txt文件傳到手機sdcard下 adb push 1.txt /sdcard 6、進入對應的設備里 adb shell 7、切入sdcard目錄 cd /sdcard 8、ls 查…

Tablesaw封裝Plot.ly實現數據可視化

上文介紹tablesaw的數據處理功能&#xff0c;本文向你展示其數據可視化功能&#xff0c;并通過幾個常用圖表示例進行說明。 Plot.ly包裝 可視化是數據分析的重要組成部分&#xff0c;無論你只是“查看”新數據集還是驗證機器學習算法的結果。Tablesaw是一個開源、高性能的Java…

Python實現中國象棋

探索中國象棋 Python 代碼實現&#xff1a;從規則邏輯到游戲呈現 中國象棋&#xff0c;這款源遠流長的棋類游戲&#xff0c;承載著深厚的文化底蘊與策略智慧。如今&#xff0c;借助 Python 與 Pygame 庫&#xff0c;我們能夠在數字世界中復刻其魅力&#xff0c;深入探究代碼背后…

互聯網、物聯網的相關標準

互聯網的相關標準 網絡通信協議&#xff1a; HTTP&#xff08;Hypertext Transfer Protocol&#xff09;&#xff1a;用于在網絡中傳輸文本、圖像、音頻和視頻等數據的協議。它基于請求-響應模型&#xff0c;客戶端發送請求給服務器&#xff0c;服務器返回響應。HTTPS&a…

學習Ajax (概述,應用場景,使用jQury 實現ajax)

目錄 前言 概述 什么是Ajax? 同步交互與異步交互的區別是什么呢&#xff1f; 應用場景 場景1 在搜索框搜索 資源 場景2 登錄業務的對用戶名處理 AJAX的優缺點 優點&#xff1a; 缺點&#xff1a; 使用jQury 實現ajax 使用步驟 1 引入jQury 文件 2 使用Ajax 函數…

網迅通推出新一代智能家居拓展網關

Zigbee 型智能家居拓展網關 產品概述 A、概述 Zigbee 是一種短距離、低功耗的無線通信技術名稱。其特點是近距離、低復雜度、低功耗、低數據速率、低成本。ZigBee 模塊是一種物聯網無線數據終端&#xff0c;利用 ZigBee 網絡為用戶提供無線數據傳輸功能。該產品采用高性能的…

ArcGIS字符串補零與去零

我們有時候需要 對屬性表中字符串的補零與去零操作 我們下面直接視頻教學 下面看視頻教學 ArcGIS字符串去零與補零 推薦學習 ArcGIS全系列實戰視頻教程——9個單一課程組合 ArcGIS10.X入門實戰視頻教程&#xff08;GIS思維&#xff09; ArcGIS之模型構建器&#xff08;Mod…

NIFI使用

1 從Kafka接收消息&#xff0c;存儲到數據庫中。 &#xff08;1&#xff09; ConsumerKafka processor &#xff08;2&#xff09;Execute Scripts Processor 我這里是使用JS腳本進行處理。 還有很多其他語言的腳本。 var flowFile session.get(); if (flowFile ! null) {v…

linux系統使用nginx代理mysql數據庫

##使用nginx代理mysql數據庫 ##安裝nginx ./configure --prefix/home/yym/nginx/nginx-install/ --with-http_addition_module --with-http_realip_module --with-stream make && make install ##nginx配置文件 stream { upstream mysqlserver { serv…

kubeadm安裝K8s集群之高可用組件keepalived+nginx

系列文章目錄 1.kubeadm安裝K8s集群之基礎環境配置 2.kubeadm安裝K8s集群之高可用組件keepalivednginx 3.kubeadm安裝K8s集群之master節點加入 4.kubeadm安裝K8s集群之worker1節點加入 kubeadm安裝K8s集群之高可用組件keepalivednginx 1.安裝kubeadm、kubectl、kubelet2.安裝高…

子網劃分實例

看到有人問這個問題&#xff1a; 想了一下&#xff0c;這是一個子網劃分的問題&#xff1a; 處理方法如圖&#xff1a; 這是一個子網劃分的問題 設備1用三層交換機&#xff0c;端口設置為路由模式&#xff0c;設備2和設備3為傻瓜交換機模式 設備2和設備3下掛設備都是26為掩碼&…

【前端知識】微前端框架qiankun

微前端框架qiankun 簡介一、核心思想二、主要特性三、關鍵技術四、使用場景五、使用示例六、優勢與劣勢七、總結 使用一、創建主應用&#xff08;Angular CLI項目&#xff09;二、創建子應用&#xff08;Vue CLI項目&#xff09;三、啟動并測試 使用場景一、大型前端應用的拆分…

Ubuntu22.04深度學習環境安裝【Anaconda+Pycharm】

anaconda可以提供多個獨立的虛擬環境&#xff0c;方便我們學習深度學習&#xff08;比如復現論文&#xff09;&#xff1b; Pycharm編輯器可以高效的編寫python代碼&#xff0c;也是一個很不錯的工具。 下面就記錄下Ubuntu22.04的安裝流程&#xff1a; 1.Anaconda安裝 下載Ana…

Transformer圖解

前言 transformer是目前NLP甚至是整個深度學習領域不能不提到的框架&#xff0c;同時大部分LLM也是使用其進行訓練生成模型&#xff0c;所以transformer幾乎是目前每一個機器人開發者或者人工智能開發者不能越過的一個框架。接下來本文將從頂層往下去一步步掀開transformer的面…