MySQL MHA配置常見問題

来源:http://www.cnblogs.com/roucheng/archive/2016/06/05/mysqlmha.html
-Advertisement-
Play Games

MHA在MySQL資料庫中被廣泛使用,它小巧易用,功能強大,實現了基於MySQL replication架構的自手動主從故障轉移,從庫重定向到主庫並自動同步。儘管如此,在部署配置的過程中,由於疏忽總難以避免這樣或那樣的錯誤。本文是對MHA配置中常見問題的一個彙總,供大家參考。http://hover ...


MHA在MySQL資料庫中被廣泛使用,它小巧易用,功能強大,實現了基於MySQL replication架構的自手動主從故障轉移,從庫重定向到主庫並自動同步。儘管如此,在部署配置的過程中,由於疏忽總難以避免這樣或那樣的錯誤。本文是對MHA配置中常見問題的一個彙總,供大家參考。http://hovertree.com/menu/mysql/

 

1、非root用戶等效性環境等效性配置
  a、添加所有節點(含管理節點)主機名及IP到host文件,所有節點操作
  b、生成基於非root用戶(如使用mysql賬戶)的對稱密鑰,使用ssh-keygen
  c、複製公鑰到其他各節點(含管理節點),如下,且使用了非預設ssh 埠
    ssh-copy-id -i ~/.ssh/id_rsa.pub "-p 50011 [email protected]
  d、驗證等效性(首次需要輸入密碼)
    ssh -p 50011 vdbsrv1 date;ssh -p 50011 vdbsrv2 date;ssh -p 50011 vdbsrv3 date;ssh -p 55555 vdbsrv4 date

 

2、MHA管理節點目錄許可權問題
  ###如果在管理節點使用了非root用戶進行mha管理,則需要相關許可權,否則報錯
  ###如下我們使用mysql用戶管理mha,則在root賬戶先創建相關目錄,在賦權給mysql
  # mkdir -p /var/log/masterha/app1
  # chown -R mysql:mysql /var/log/masterha
  # su - mysql
  $ masterha_check_repl --conf=/etc/app1.cnf   ###使用mysql用戶校驗複製關係

 

3、需要添加用於登陸到mysql伺服器賬戶
  ###需要STOP SLAVE, CHANGE MASTER, RESET SLAVE等相關許可權,該賬戶要添加到mha配置文件中,主從切換時用到
  ###在mysql資料庫各節點執行,如下由於跨網段,所以分配了跨網段賬戶,否則,單條賦權即可
  ### Author : Leshami
  ### Blog   : http://blog.csdn.net/leshami
  mysql> grant all privileges on *.* to 'mha'@'172.16.16.%' identified by '***';
  Query OK, 0 rows affected (0.00 sec)
  
  mysql> grant all privileges on *.* to 'mha'@'192.168.1.%' identified by '***';
  Query OK, 0 rows affected (0.00 sec)

 

4、需要添加用於建立複製關係的賬戶
  ###在mysql資料庫各節點執行,如下由於跨網段,所以分配了跨網段賬戶,否則,單條賦權即可
  mysql> grant replication slave on *.* to 'repl'@'172.16.16.%' identified by '***';
  Query OK, 0 rows affected (0.00 sec)
  
  mysql> grant replication slave on *.* to 'repl'@'192.168.1.%' identified by '***';
  Query OK, 0 rows affected (0.00 sec)

 

5、從庫的各客戶端應開啟binlog,即log_bin=on
  ###未開啟則收到如下提示:
  Mon Apr 13 20:02:15 2015 - [warning]  log-bin is not set on slave SZ-DB-SLAVE01(192.168.81.3:3306). 
  This host cannot be a master.

 

6、各主從庫應該使用相同的複製過濾規則
  ###否則收到如下的錯誤提示:
  Mon Apr 13 20:02:15 2015 - [error][/usr/lib/perl5/site_perl/5.8.8/MHA/ServerManager.pm, ln546] Replication 
      filtering check failed on dbsrv3(192.168.1.3:3306)! All slaves must have same replication filtering rules.
      Check SHOW SLAVE STATUS output and set my.cnf correctly.
  Mon Apr 13 20:02:15 2015 - [warning] Bad Binlog/Replication filtering rules:

 

7、各從庫應設置relay_log_purge=0
  ###否則收到以下告警信息 ##mysql -e 'set global relay_log_purge=0' 動態修改該參數,因為隨時slave會提升為master。補充@150420
  Mon Apr 13 20:02:15 2015 - [warning]  relay_log_purge=0 is not set on slave vdbsrv2(172.16.16.12:3306).
  

8、各從庫設置read_only=1
  ###否則收到以下告警信息 ## mysql -e 'set global read_only=1' 動態修改該參數,因為隨時slave會提升為master。補充@150420
  Mon Apr 13 20:19:54 2015 - [info]  read_only=1 is not set on slave vdbsrv3(172.16.16.13:3306).

 

9、mysqlbinlog version過低
  ###大多數情況下我們使用yum方式安裝perl-DBD-MySQL,該方式會自動安裝mysql rpm包。
  ###MHA在執行master_check_repl會調用/usr/bin/mysqlbinlog,對於源碼安裝在不同的路徑的mysql高版本
  ###則收到如下錯誤提示:
  Thu Apr 16 14:01:44 2015 - [info]   Connecting to [email protected](vdbsrv2:22).. 
  mysqlbinlog version is 3.2 (included in MySQL Client 5.0 or lower). This is not recommended. 
    Consider upgrading MySQL Client to 5.1 or higher.
  
  ###解決方案是編譯安裝perl-DBD-MySQL時指定mysql安裝位置,或者參考:mysqlbinlog can not parse row based events
  

10、預設路徑下mysql客戶端如果不存在則出現以下提示
  ###通過建立軟鏈或者yum install perl-DBD-MySQL會自動安裝mysql
  Testing mysql connection and privileges..sh: mysql: command not found
  mysql command failed with rc 127:0!
   at /usr/bin/apply_diff_relay_logs line 375

 

11、清理mysql.user用戶表中用戶名為空的記錄(補充@20150421)

    筆者有一次在做線上切換時發現複製賬戶從一個slave可以到新master,而無法從original master連接到新master,刪除用戶為空記錄後正常

推薦:http://www.cnblogs.com/roucheng/p/mysqljichu.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如果要讓後退按鈕顯示出來,需要在後臺添加如下的代碼 當然添加這行代碼後僅僅是出現一個後退的箭頭而已,點擊後並沒反應,需要繼續添加監聽事件才行,預設添加的按鈕id是固定的,android.R.id.home,在onOptionsItemSelected中再添加如下的監聽事件 其實這樣並不是真正意義上的 ...
  • 1、文件的讀取 io流讀取文件,並且顯示 其中訪問android的"data/data/com.helloword/file"建立過程如下 打開file explore,即可看到Android 的文件 打開cmd,進入sdk platform-tool >adb shell $ su # chmod ...
  • 在《Android 在內部存儲讀寫文件》一文中,談到了登錄用戶名和密碼的方法,通過讀取記憶體文件來實現,但是會出現問題,因為登錄名和密碼的形式通過username##password的形式,讀取的時候以##為分割線,但是一旦用戶名中存在##就會出現問題,本文使用SharedPreference來解決這 ...
  • LeanCloud算是一個簡單易用的雲伺服器,其中包含了強大的資料庫支持,我們只需要將此伺服器應用到本地的代碼即可實現後臺的存儲與交互。 那麼,如何簡單實現本地代碼和LeanCloud伺服器的交互呢?下麵我們詳細解釋: 首先,開發環境:Android Studio 1.5(下麵簡稱AS) 第一步:使 ...
  • 待解析的JSON格式的文件如下: [{"id":"5", "version":"1.0", "name":"xiaowang"}, {"id":"10", "version":"2.0", "name":"lisi"}] 一、使用JSONObject來解析JSON數據 官方提供的,所有不需要導入第三 ...
  • 在SQL2005資料庫中利用SQL語句進行數據備份與還原: 備份backup:backup database 資料庫名稱 tO disk = 備份路徑例:BACKUP DATABASE test TO disk = 'd:\bak\test.bak' 恢復restore:restore databa ...
  • 【故障處理】 DBCA建庫報錯CRS-2566 PRCR-1071 PRCR-1006 一.1 BLOG文檔結構圖 一.2 前言部分 一.2.1 導讀和註意事項 各位技術愛好者,看完本文後,你可以掌握如下的技能,也可以學到一些其它你所不知道的知識,~O(∩_∩)O~: ① dbca靜默建庫 ② 將監... ...
  • 背景介紹: 基於shiro新開發的許可權認證系統,在授權部分採用ehcache作為緩存。系統採用分散式集群部署,因此需要配置ehcache支持集群間緩存的同步 1、配置兩台tomcat,ip一致為本機IP 2、採用rmi方式實現緩存同步。修改ehcache配置文件,一般為ehcache.xml。在其中 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...