mysql高可用之LVS + KEEPALIVE + MYSQL

来源:http://www.cnblogs.com/zhanchenjin/archive/2016/04/11/5378906.html
-Advertisement-
Play Games

1.架構圖 註意 (一) Mysql需要把bind-address的配置去掉,否則無法實現虛擬ip訪問 (二) 關閉所有linux防火牆:/sbin/iptables –F(可能沒用) (三) 重啟networking:sudo /etc/init.d/networking restart(可能沒用 ...


1.架構圖

 

 

註意

(一)   Mysql需要把bind-address的配置去掉,否則無法實現虛擬ip訪問

(二)   關閉所有linux防火牆:/sbin/iptables –F(可能沒用)

(三)   重啟networking:sudo /etc/init.d/networking restart(可能沒用)

 

 

2. 架構

Mysql:

master<=slave

10.24.6.5:3306(system   !System)<=10.24.6.6:3306(system          !System) 

LB

10.24.6.4 Master

10.24.6.7 BACKUP

VIP:

10.24.6.2

 

 

3.LVS負載均衡配置

3.1. Lvs模塊檢測

Ipvs 具體實現是由ipvsadm 這個程式來完成,因此判斷一個系統是否具備ipvs 功能,只需要察看ipvsadm 程式是否被安裝。察看ipvsadm 程式最簡單的辦法就是在任意路徑執行命令ipvsadm。表6-1 為安裝ipvsadm 及未安裝ipvsadm 的輸出對比。

 

執行 ipvsadm 後的輸出

未安裝ipvsadm

bash: /sbin/ipvsadm: 沒有那個文件或目錄

安裝ipvsadm

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Scheduler Flags

  ->RemoteAddress:Port           Forward Weight ActiveConn InActConn

 

表6-1 ipvsadm 輸出對比

 

 

a)         通過系統命令比較簡單:apt-get install ipvsadm

b)        檢驗ipvsadm 是否被正確安裝

                                    i.              執行ipvsadm,看是否有表6-1 第2 欄的輸出。

                                  ii.              檢查當前載入的內核模塊,看是否存在ip_vs 模塊。

 

modprobe -l |grep ipvs 

或lsmod | grep ip_vs

 

Ubuntu9.10已經用了2.6的內核,所以不需要再編譯內核了

 

 

 

3.2.配置

LVS預設不需要配置

 

4.KeepAlived高可用配置

4.1. 安裝

 

 

 

4.2. MASTER配置(/etc/keepalived/keepalived.conf)

global_defs {

    router_id HaMySQL_1

}

vrrp_instance VI_MYSQL {

    state MASTER

    interface eth0

    virtual_router_id 51

    priority 100

    advert_int 1

    authentication {

        auth_type PASS

        auth_pass 1111

    }

    virtual_ipaddress {

        10.24.6.2

    }

}

virtual_server 10.24.6.2 3306 {

    delay_loop 6

    lb_algo wrr

    lb_kind DR

    persistence_timeout 60

    protocol TCP

    real_server 10.24.6.5 3306 {

        weight 3

        TCP_CHECK {

        connect_timeout 3

        nb_get_retry 3

        delay_before_retry 3

        connect_port 3306

        }

    }

    real_server 10.24.6.6 3306 {

        weight 3

        TCP_CHECK {

        connect_timeout 3

        nb_get_retry 3

        delay_before_retry 3

        connect_port 3306

        }

}

}

4.3. SLAVE配置(/etc/keepalived/keepalived.conf)

global_defs {

    router_id HaMySQL_1

}

vrrp_instance VI_MYSQL {

    state BACKUP

    interface eth0

    virtual_router_id 51

    priority 50

    advert_int 1

    authentication {

        auth_type PASS

        auth_pass 1111

    }

    virtual_ipaddress {

        10.24.6.2

    }

}

virtual_server 10.24.6.2 3306 {

    delay_loop 6

    lb_algo wrr

    lb_kind DR

    persistence_timeout 60

    protocol TCP

    real_server 10.24.6.5 3306 {

        weight 3

        TCP_CHECK {

        connect_timeout 3

        nb_get_retry 3

        delay_before_retry 3

        connect_port 3306

        }

    }

    real_server 10.24.6.6 3306 {

        weight 3

        TCP_CHECK {

        connect_timeout 3

        nb_get_retry 3

        delay_before_retry 3

        connect_port 3306

        }

    }

}

 

 

4.4. 日誌

Ubuntu下麵是/var/log/syslog

All daemon messages are logged through the Linux syslog. If you start Keepalived with the “dump

configuration data” option, you should see in your /var/log/messages (on Debian this may be

/var/log/daemon.log depending on your syslog configuration) something like this :

 

 

4.5. 負載均衡服務的啟用和驗證

Lvs 客戶端的啟用和驗證在前面的有過詳細的說明,此處略過。前面我們也提過,keepalived 啟動過程不會檢查配置文件的語法,因此在啟動keepalived 以前,需要人工對/etc/keepalived/keepalived.conf 文件做全面的語法檢查。一個比較容易犯的錯誤就是把花括弧“}”寫漏了,不成對!當lvs 客戶端都正常啟動並且配置文件經檢查無誤後(當然有錯誤也無妨,隨時可以修改嘛!),執行命令 /usr/local/keepalived/sbin/keepalived –D ,然後我們查看系統進程,看是否是3 個keepalived 進程。如果配置文件的路徑不是/etc/keepalived/keepalived.conf 則需要在啟動時用選項-f 指定。

最能反映keepalived 啟動情況的地方當屬系統日誌。手動執行啟動操作後,使用命令 tail –f /var/log/syslog 滾動查看輸出,就能詳細瞭解其運行情況。圖6-3 為某個lvs 環境的keepalived 啟動輸出:

另外一個反映keepalived 正常運行狀態的地方是網路介面vip 的啟用。通過執行ip add 即可看見vip 已經被綁定在制定的網路介面(註意:ifconfig 不能顯示 vip)。需要註意的是,BACKUP 的vip 暫時不綁定。如下圖所示:

4.6. Vip驗證

Master

 

Slave

 

4.7. IPVSADM驗證

Master

 

Clave

 

 

4.8. 測試驗證

 

實體mysql

 

 

Vip mysql

 

 

 

4.9. 高可用測試結果

LB:

10.24.6.4 Master關閉以後,10.24.6.7 BACKUP啟用接管

MYSQL:

10.24.6.5:3306

10.24.6.6:3306

任意一個mysql異常之後,可連接到其他mysql

 

 

 

5. 遇到問題

5.1. Mysql連接不上(錯誤碼111)分析

1.Mysql連接vip

 

2.Mysql連接vip的抓包情況

 

通過抓包可知,10.24.6.2:3306是可以連上的,它有回包,只不過回包的狀態為R

 

3.TCP連接出現RST的情況分析:

  @1埠未打開

  @2請求超時

  @3提前關閉

  @4在一個已關閉的socket上收到數據

4.在結合mysql返回值為111可以知道應該是mysql服務提前關閉了,

Google了下mysql111的解決辦法:

QT鏈接Mysql的時候出現QSqlError(2003, "QMYSQL: Unable to connect", "Can't connect to MySQL server on '172.18.186.244' (111)")錯誤,google之後發現是mysql為了安全,對hostname進行了綁定。

解決辦法:修改/etc/mysql/my.cnf(不同Linux發行版位置可能不同,我用的是Ubuntu 11.04,windows是my.ini文件),裡面有一句:bind-address = 127.0.0.1用#註釋掉,重啟mysql服務就OK了。

原文地址:http://stackoverflow.com/questions/1420839/cant-connect-to-mysql-server-error-111

5. 解決方案(去掉bind-address):

修改在10.24.6.5的mysql配置:

 

 

修改在10.24.6.6的mysql配置:

 


6. 總結

  • 主mysql和從mysql可以同時存在服務
  • Keepalive從可用的服務列表裡面選擇一個服務訪問
  • 主mysql和從mysql隨機選擇
  • 適合做負載均衡,主從備份
  • share nothing架構

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

-Advertisement-
Play Games
更多相關文章
  • HBase是一種資料庫:HadoopDatabase顧名思義就是Hadoop資料庫,它是一種基於hadoop文件系統HDFS的一種分散式資料庫,專門設計用來快速隨機讀寫大規模數據。本文介紹HBase的下載與安裝的整個過程。 一、HBase的下載 1.登錄HBase官網http://hbase.apa ...
  • 一、選擇Percona Server、MariaDB還是MYSQL mysql應用源碼:http://www.jinhusns.com/Products/Download/?type=xcj 1、Mysql三種存儲引擎 MySQL提供了兩種存儲引擎:MyISAM和 InnoDB,MySQL4和5使用 ...
  • 接上一篇Mysql性能優化一 建立適當的索引 說起提高資料庫性能,索引是最物美價廉的東西了。不用加記憶體,不用改程式,不用調sql,只要執行個正確的'create index',查詢速度就可能提高百倍千倍,這可真有誘惑力。可是天下沒有免費的午餐,查詢速度的提高是以插入、更新、刪除的速度為代價的,這些寫 ...
  • 在部署環境時,不同的環境可能會有一些不同步,而個人遇到的問題就是在開發環境中表中均有欄位 BestCaseId 和 RiskId 欄位,生產環境中目前只有 BestCaseId 欄位,新搭建的測試環境中暫時都不存在這兩個欄位(某些原因需要另一單獨測試環境)。 保證在生產環境中的 BestCaseId ...
  • 1. Linux系統配置 1.1. vm.overcommit_memory設置 overcommit_memory文件指定了內核針對記憶體分配的策略,其值可以是0、1、2。 0, 表示內核將檢查是否有足夠的可用記憶體供應用進程使用;如果有足夠的可用記憶體,記憶體申請允許;否則,記憶體申請失敗,並把錯誤返回給 ...
  • 1. Redis主從配置 1.1. 設置主從複製 Master <= Salve 10.24.6.5:6379 <= 10.24.6.7:6379 1.2. 取消主從複製 1.3. 刪除所有數據 flushdb:刪除這個db下的。 flushall:刪除所有 2. Sentinel高可用配置 Sen ...
  • Range --創建分區表 create table emp3(id number(4) primary key,name varchar2(20),eff_dt date) partition by range(eff_dt) ( partition p1 values less than (to ...
  • 1. 參考文檔 http://xuwensong.elastos.org/2014/01/13/ubuntu-%E4%B8%8Bmysql-cluster%E5%AE%89%E8%A3%85%E5%92%8C%E9%85%8D%E7%BD%AE/ 2. 簡介 MySQL-Cluster是一種技術,該 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...