日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

部署MNA高可用

發布時間:2024/3/12 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 部署MNA高可用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

MHA工作原理總結為以下幾條:
(1) 從宕機崩潰的 master 保存二進制日志事件(binlog events);
(2) 識別含有最新更新的 slave ;
(3) 應用差異的中繼日志(relay log) 到其他 slave ;
(4) 應用從 master 保存的二進制日志事件(binlog events);
(5) 通過Manager控制器提升一個 slave 為新 master ;
(6) 使用其他的 slave 連接新的 master 進行復制。
準備環境:

名稱IP
mysql-master10.0.0.194
mysql-slave110.0.0.195
mysql-slave210.0.0.196
mysql-mha10.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高可用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。