MySQL - MMM 實現 MySQL 高可用

  • MMM (Master-Master replication manager for MySQL,MySQL 主主複製管理器)是一套支持雙主故障切換和雙主平常管理的腳本程序。MMM 使用 Perl 語言開發,主要用來監控和管理 MySQL Master-Master(雙主)複製,雖然也叫雙主複製,可是業務上同一時刻只容許對一個主進行寫入,另外一臺備選主上提供部分讀服務,以加速在主主切換時備選主的預熱,能夠說 MMM 這套腳本程序一方面實現了故障切換的功能,另外一方面其內部附加的工具腳本也能夠實現多個 Slave 的 read 負載均衡。mysql

  • MMM提供了自動和手動兩種方式移除一組服務器中複製延遲較高的服務器的虛擬 ip,同時它還能夠備份數據,實現兩節點之間的數據同步等。因爲 MMM 沒法徹底保證數據的一致性,因此 MMM 適用於對數據的一致性要求不是很高,可是又想最大程度的保證業務可用性的場景。對於那些對數據的一致性要求很高的業務,很是不建議採用 MMM 這種高可用架構。sql

  • 關於 MMM 高可用架構的說明以下:
    mmm_mon:監控進程,負責全部的監控工做,決定和處理全部節點角色活動。此腳本須要在監管機上運行。
    mmm_agent:運行在每一個 MySQL 服務器上的代理進程,完成監控的探針工做和執行簡單的遠端服務shezhi.cijiaoben須要在被監管機上運行。
    mmm_control:一個簡單的腳本,提供管理 mmm_mond 進程的命令。
    mysql-mmm 的監管端會提供多個虛擬 IP (VIP),包括一個可寫 VIP,多個可讀 VIP,經過監管的管理,這些 IP 會綁定在可用 MySQL 之上,當某一臺 MySQL 宕機時,監管會將 VIP 遷移至其餘 MySQL。

部署環境

主機 操做系統 IP地址 VIP地址
mysql-m1主服務器 CentOS 7.4 x86_64 192.168.100.200 192.168.100.100(Writer)
mysql-m2主服務器 CentOS 7.4 x86_64 192.168.100.201 192.168.100.100(Writer)
mysql-monitor CentOS 7.4 x86_64 192.168.100.204
mysql-m3從服務器 CentOS 7.4 x86_64 192.168.100.202 192.168.100.101(Reader)
mysql-m4從服務器 CentOS 7.4 x86_64 192.168.100.203 192.168.100.102(Reader)

開始部署

  • 安裝所需軟件包,修改配置文件(四臺MySQL服務器操做一致)
  1. 搭建ALI雲源,安裝epel-release源。數據庫

    wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo    #下載ALI雲源
    yum -y install epel-release    #安裝epel-release源
    yum clean all && yum makecache    #清空緩存,生成新的緩存文件
  2. 安裝 MariaDB 數據庫,開啓服務(和MySQL同源,搭建步驟相同)vim

    yum -y install mariadb-server mariadb
    systemctl stop firewalld.service
    setenforce 0
    systemctl start mariadb
  3. 修改數據庫主配置文件,發往其餘主機並啓動服務器
    # vim /etc/my.cnf
    [mysqld]
    log_error=/var/lib/mysql/mysql.err    #錯誤日誌文件位置
    log=/var/lib/mysql/mysql_log.log    #訪問日誌文件位置
    log_slow_queries=/var/lib/mysql_slow_queris.log    #慢日誌文件位置
    binlog-ignore-db=mysql,information_schema    #不生成二進制文件的庫
    character_set_server=utf8    #使用的字符集
    log_bin=mysql_bin    #二進制日誌文件功能
    server_id=1
    log_slave_updates=true    #開啓同步
    sync_binlog=1
    auto_increment_increment=2
    auto_increment_offset=1
    # scp /etc/my.cnf root@192.168.100.201:/etc
    # scp /etc/my.cnf root@192.168.100.202:/etc
    # scp /etc/my.cnf root@192.168.100.203:/etc
    # 注:另外三臺主機的配置文件裏的server_id要作修改,保證不一致便可
  • 配置主主複製(m1和m2兩臺主服務器互相同步)
  • 查看對方的日誌文件名稱和偏移值緩存

    mysql> show master status;
  • 主服務器互相提高訪問權限(m一、m2服務器分別執行)服務器

    # mysql-m1
    grant replication slave on *.* to 'replication'@'172.168.100.%' identified by '123456';
    # 使用帳戶爲replication 密碼爲123456
    change master to master_host='172.168.100.201',master_user='replication',master_password='123456',master_log_file='mysql_bin.000003',master_log_pos=245;
    # 當在MariaDB-m1上執行時,master_host地址爲MariaDB-m2地址
    ···
    # mysql-m2
    grant replication slave on *.* to 'replication'@'172.168.100.%' identified by '123456';
    change master to master_host='172.168.100.200',master_user='replication',master_password='123456',master_log_file='mysql_bin.000003',master_log_pos=245;
    # 當在MariaDB-m2上執行時,master_host地址爲MariaDB-m1地址
  • 開啓同步,查看服務器的主從狀態架構

    start slave;
    show slave status\G;
    # Slave_IO_Running: Yes
    # Slave_SQL_Running: Yes
  • 配置m三、m4服務器做爲從服務器負載均衡

    show master status;
    # 查看m1服務器的日誌文件以及偏移值(注意日誌文件和偏移值的改變)
    # m1和m2互相同步,在此只需執行m1便可
    change master to master_host='172.168.100.200',master_user='replication',master_password='123456',master_log_file='mysql_bin.000004',master_log_pos=245;
    # m3和m4上分別執行
  • 分別查看m3和m4的主從狀態ide

    start slave;
    show slave status\G;
    # Slave_IO_Running: Yes
    # Slave_SQL_Running: Yes
  • 安裝配置MMM架構
    前面咱們使用wget配置了ALI雲源並簡易安裝 MariaDB 來代替 MySQL ,並搭建了主主同步,主從複製以便完成實驗,如今咱們來完成MMM架構工具

  • 安裝mysql-mmm,修改配置文件(五臺主機配置相同)

    # yum -y install mysql-mmm*     //前面咱們配置了epel源,直接yum安裝
    # vim /etc/mysql-mmm/mmm_common.conf  //配置以下
    active_master_role      writer
    <host default>
    cluster_interface       ens33
    pid_path                /run/mysql-mmm-agent.pid
    bin_path                /usr/libexec/mysql-mmm/
    replication_user        replication
    replication_password    123456
    agent_user              mmm_agent
    agent_password          123456
    </host>
    <host db1>
    ip      172.168.100.200
    mode    master
    peer    db2
    </host>
    <host db2>
    ip      172.168.100.201
    mode    master
    peer    db1
    </host>
    <host db3>
    ip      172.168.100.202
    mode    slave
    </host>
    <host db4>
    ip      172.168.100.203
    mode    slave
    </host>
    <role writer>
    hosts   db1, db2
    ips     172.168.100.100
    mode    exclusive
    </role>
    <role reader>
    hosts   db3, db4
    ips     172.168.100.101, 172.168.100.102
    mode    balanced
    </role>
  • 快速爲其餘主機修改配置文件

    scp mmm_common.conf root@192.168.100.200:/etc/mysql-mmm/
    scp mmm_common.conf root@192.168.100.201:/etc/mysql-mmm/
    scp mmm_common.conf root@192.168.100.202:/etc/mysql-mmm/
    scp mmm_common.conf root@192.168.100.203:/etc/mysql-mmm/
  • 在主機上修改mmm_agent.conf文件的名稱

    # vim /etc/mysql-mmm/mmm_agent.conf
    this db1  //按照規劃分別修改成db一、db二、db三、db4
  • 在全部主機上對mmm_agent、mmm_moniter進行受權

    mysql> grant super, replication client, process on *.* to 'mmm_agent'@'192.168.100.%' identified by '123456';
    mysql> grant replication client on *.* to 'mmm_monitor'@'192.168.100.%' identified by '123456';
    # flush privileges;  //從新加載權限表
  • 配置監控主機(在mysql-monitor上配置)

    # vim /etc/mysql-mmm/mmm_mon.conf
    include mmm_common.conf
    <monitor>
    ip                  127.0.0.1
    pid_path            /run/mysql-mmm-monitor.pid
    bin_path            /usr/libexec/mysql-mmm
    status_path         /var/lib/mysql-mmm/mmm_mond.status
    ping_ips            172.168.100.200,172.168.100.201,172.168.100.202,172.168.100.203
    auto_set_online     10    #上線時間修改成10s
    # The kill_host_bin does not exist by default, though the monitor will
    # throw a warning about it missing.  See the section 5.10 "Kill Host
    # Functionality" in the PDF documentation.
    #
    # kill_host_bin     /usr/libexec/mysql-mmm/monitor/kill_host
    #
    </monitor>
    <host default>
    monitor_user        mmm_monitor
    monitor_password    123456
    </host>
    debug 0
  • 關閉防火牆及加強×××

    systemctl disable firewalld.service
    systemctl stop firewalld.service
    setenforce 0
  • 啓動服務,查看各節點狀態
    systemctl start mysql-mmm-monitor.service
    # ERROR: Can't connect to monitor daemon!,如若出現報錯,可嘗試重啓服務解決
    mmm_control check all
    # 檢查監控服務器對全部主機的監控是否完善
    # 檢查結果所有OK,則部署完成

至此,MySQL-MMM已經部署成功,進一步的話,咱們能夠結合Amoeba實現讀寫分離,Writer 的虛擬VIP能夠寫入數據庫,而 Reader 能夠用來讀取數據。並經過Keepalived對 monitor 服務器進行雙機熱備。

相關文章
相關標籤/搜索