欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

初識MariaDB之7——MHA高可用-創(chuàng)新互聯(lián)

一、背景介紹

公司主營業(yè)務:成都做網(wǎng)站、成都網(wǎng)站制作、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)公司推出昭化免費做網(wǎng)站回饋大家。

在傳統(tǒng)的MySQL一主一從或一主多從結構中,主節(jié)點存在單點故障隱患,為了解決該故障,進而引入了MHA高可用的方式。MHA由manager和node兩部分組成,manager可以安裝在一個獨立的服務器上或非master角色的MySQL服務器上,1個manager可以管多個node集合,每一個master/node集群稱為一個application,所有集群可以使用一個配置文件或者為每個集群創(chuàng)建單獨的配置文件,目前MHA最少由3個主機組成

初識MariaDB之7——MHA高可用初識MariaDB之7——MHA高可用

二、實現(xiàn)原理

MHA是在MySQL主從復制基礎上實現(xiàn)的高可用,其實現(xiàn)原理是:

在正常情況下,MHA的manager節(jié)點對所有node節(jié)點周期性進行健康狀態(tài)檢測,當MySQL的master節(jié)點出現(xiàn)故障時,MHA的manager試圖從宕機的MySQL的master上將二進制日志保存到本地,并與所有node節(jié)點的中繼日志進行對比,將擁有最新同步狀態(tài)的slave主機提升為master主機,所有slave主機指向新的master主機。

初識MariaDB之7——MHA高可用初識MariaDB之7——MHA高可用

三、實驗環(huán)境

本次實驗采用CentOS7.4系統(tǒng),數(shù)據(jù)庫版本5.5.56-MariaDB,MHA版本mha4mysql-manager-0.58。因為所有服務器之間要傳輸中繼日志,并且還需要指定master,所有所有主機間要建立密鑰認證,master和candidate節(jié)點需要創(chuàng)建用于從服務器復制的二進制日志的賬號,MySQL每個服務器都需要創(chuàng)建可以指定master的賬號,并且master和candidate節(jié)點不能開啟relay_log_purge選項,為了大程度的保證數(shù)據(jù)的不丟失,建議將candidate配置成半同步形式。

MHA角色

MySQL角色

IP地址

開啟MySQL功能

manager

172.16.10.30/24

node

master

172.16.10.40/24

1.二進制日志,中繼日志

2.復制賬號,管理賬號

3.中繼日志不能裁剪

4.半同步master插件

node/candidate

slave

172.16.10.50/24

1.二進制日志,中繼日志

2.復制賬號,管理賬號

3.中繼日志不能裁剪

4.半同步slave插件

5.只讀模式

node

slave

172.16.10.60/24

1.中繼日志

2.只讀模式

初識MariaDB之7——MHA高可用初識MariaDB之7——MHA高可用

四、準備操作

既然是集群時間同步和名稱解析就需要提前完成,此處不過多介紹

1.所有主機互信

可以在一個主機生成一對密鑰,將這對密鑰和know_hosts文件拷貝給其余主機的方式,不需要所有主機都生成密鑰對相互拷貝

[root@host3 ~]# ssh-keygen

[root@host3 ~]# ssh-copy-id 172.16.10.30

[root@host3 ~]# ssh-copy-id 172.16.10.40

[root@host3 ~]# ssh-copy-id 172.16.10.50

[root@host3 ~]# ssh-copy-id 172.16.10.60

[root@host3 .ssh]# scp -r id_rsa known_hosts root@172.16.10.40:/root/.ssh/

[root@host3 .ssh]# scp -r id_rsa known_hosts root@172.16.10.50:/root/.ssh/

[root@host3 .ssh]# scp -r id_rsa known_hosts root@172.16.10.60:/root/.ssh/

2.安裝Mariadb數(shù)據(jù)庫

[root@host4 ~]# yum install mariadb-server.x86_64 -y

[root@host5 ~]# yum install mariadb-server.x86_64 -y

[root@host6 ~]# yum install mariadb-server.x86_64 -y

3.Master主機操作

(1)修改配置文件

[root@host4 ~]# vim /etc/my.cnf

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

skip_name_resolve=ON

relay_log=mysql-relaylog

relay_log_index=mysql-relaylog

relay_log_purge=OFF

slow_query_log=ON

server-id=10

innodb_file_per_table=ON

binlog_format=ROW

log_bin=mysql-binlog

log_slave_updates=ON

(2)啟動并進入MySQL

[root@host4 ~]# systemctl start mariadb.service

[root@host4 ~]# mysql

(3)創(chuàng)建用于主從復制和管理數(shù)據(jù)庫的賬號

MariaDB [(none)]>  grant replication slave on *.* to 'bak'@'172.16.10.%' identified by 'bakpass';

MariaDB [(none)]>  grant all on *.* to 'man'@'172.16.10.%' identified by 'manpass';

MariaDB [(none)]> flush privileges;

(4)開啟并激活半同步插件

MariaDB [(none)]> install plugin rpl_semi_sync_master soname 'semisync_master.so';

MariaDB [(none)]> set global rpl_semi_sync_master_enabled=ON;

(5)確定當前binlog日志及position

MariaDB [(none)]> show master status;

+---------------------+----------+--------------+------------------+

| File         | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+---------------------+----------+--------------+------------------+

| mysql-binlog.000003 |    610 |        |          |

+---------------------+----------+--------------+------------------+

4.Candidate主機操作

(1)修改配置文件

[root@host5 ~]# vim /etc/my.cnf

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

skip_name_resolve=ON

relay_log=mysql-relaylog

relay_log_index=mysql-relaylog

relay_log_purge=OFF

read_only=ON

slow_query_log=ON

server-id=20

innodb_file_per_table=ON

binlog_format=ROW

log_bin=mysql-binlog

log_slave_updates=ON

(2)啟動并進入MySQL

[root@host5 ~]# systemctl start mariadb.service

[root@host5 ~]# mysql

(3)創(chuàng)建用于主從復制和管理數(shù)據(jù)庫的賬號

MariaDB [(none)]>  set global read_only=0;

MariaDB [(none)]>  grant replication slave on *.* to 'bak'@'172.16.10.%' identified by 'bakpass';

MariaDB [(none)]>  grant all on *.* to 'man'@'172.16.10.%' identified by 'manpass';

MariaDB [(none)]> flush privileges;

MariaDB [(none)]>  set global read_only=1;

(4)開啟并激活半同步插件

MariaDB [(none)]> install plugin rpl_semi_sync_slave soname 'semisync_slave.so';

MariaDB [(none)]> set global rpl_semi_sync_slave_enabled=ON;

(5)指定主服務器及主服務器當前的binlog日志和position

MariaDB [hellodb]> change master to

  -> master_host='172.16.10.40',

  -> master_user='bak',

  -> master_password='bakpass',

  -> master_port=3306,

  -> master_log_file='mysql-binlog.000003',

  -> master_log_pos=610,

  -> master_connect_retry=10;

(6)啟動從節(jié)點

MariaDB [hellodb]> start slave [IO_THREAD | SQL_THREAD];

(7)查看從節(jié)點狀態(tài)(Slave_IO_Running和Slave_SQL_Running顯示Yes成功)

MariaDB [(none)]> show slave status \G

*************************** 1. row ***************************

       Slave_IO_State: Waiting for master to send event

         Master_Host: 172.16.10.40

         Master_User: bak

         Master_Port: 3306

        Connect_Retry: 10

       Master_Log_File: mysql-binlog.000003

     Read_Master_Log_Pos: 610

       Relay_Log_File: mysql-relaylog.000002

        Relay_Log_Pos: 532

    Relay_Master_Log_File: mysql-binlog.000003

      Slave_IO_Running: Yes

      Slave_SQL_Running: Yes

5.Slave主機操作

(1)修改配置文件

[root@host6 ~]# vim /etc/my.cnf

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

skip_name_resolve=ON

relay_log=mysql-relaylog

relay_log_index=mysql-relaylog

relay_log_purge=ON

read_only=ON

slow_query_log=ON

server-id=30

innodb_file_per_table=ON

(2)啟動并進入MySQL

[root@host6 ~]# systemctl start mariadb.service

[root@host6 ~]# mysql

(3)創(chuàng)建用于管理數(shù)據(jù)庫的賬號

MariaDB [(none)]>  set global read_only=0;

MariaDB [(none)]>  grant replication slave on *.* to 'bak'@'172.16.10.%' identified by 'bakpass';

MariaDB [(none)]>  grant all on *.* to 'man'@'172.16.10.%' identified by 'manpass';

MariaDB [(none)]> flush privileges;

MariaDB [(none)]>  set global read_only=1;

(4)指定主服務器及主服務器當前的binlog日志和position

MariaDB [hellodb]> change master to

  -> master_host='172.16.10.40',

  -> master_user='bak',

  -> master_password='bakpass',

  -> master_port=3306,

  -> master_log_file='mysql-binlog.000003',

  -> master_log_pos=610,

  -> master_connect_retry=10;

(5)啟動從節(jié)點

MariaDB [hellodb]> start slave [IO_THREAD | SQL_THREAD];

(6)查看從節(jié)點狀態(tài)(Slave_IO_Running和Slave_SQL_Running顯示Yes成功)

MariaDB [(none)]> show slave status \G

*************************** 1. row ***************************

       Slave_IO_State: Waiting for master to send event

         Master_Host: 172.16.10.40

         Master_User: bak

         Master_Port: 3306

        Connect_Retry: 10

       Master_Log_File: mysql-binlog.000003

     Read_Master_Log_Pos: 610

       Relay_Log_File: mysql-relaylog.000002

        Relay_Log_Pos: 532

    Relay_Master_Log_File: mysql-binlog.000003

      Slave_IO_Running: Yes

      Slave_SQL_Running: Yes

五、MHA高可用實現(xiàn)

1.安裝MHA軟件

(1)主節(jié)點

[root@host3 mha]# yum install mha4mysql-manager-0.58-0.el7.centos.noarch.rpm mha4mysql-node-0.58-0.el7.centos.noarch.rpm -y

-masterha_check_ssh:MHA依賴的SSH環(huán)境檢測工具;

-masterha_check_repl:MySQL復制環(huán)境檢測工具;

-masterha_manager:MHA服務主程序;

-masterha_check_status:MHA運行狀態(tài)探測工具;

-masterha_master_monitor:MySQL master節(jié)點可用性檢測工具;

-masterha_master_switch:master節(jié)點切換工具;

-masterha_conf_host:添加或刪除配置的節(jié)點;

-masterha_stop:關閉MHA服務的工具;

(2)從節(jié)點

[root@host4 mha]# yum install mha4mysql-node-0.58-0.el7.centos.noarch.rpm -y

-save_binary_logs:保存和復制master的二進制日志;

-apply_diff_relay_logs:識別差異的中繼日志事件并用于其他slave;

-fiter_mysqlbinlog:去除不必要的ROLLBACK事件(MHA已不再使用這個工具);

-purge_relay_logs:清除中繼日志(不會阻塞SQL線程);

2.在MHA的Manager節(jié)點創(chuàng)建配置文件并檢測

[root@host3 ~]# mkdir /etc/mha

[root@host3 ~]# vim /etc/mha/app1.conf

[server default]

user=man

password=manpass

manager_workdir=/data/masterha/app1

manager_log=/data/masterha/app1/manager.log

remote_workdir=/data/masterha/app1

ssh_user=root

ping_interval=1

repl_user=bak

repl_password=bakpass

[server1]

hostname=172.16.10.40

candidate_master=1

[server2]

hostname=172.16.10.50

candidate_master=1

[server3]

hostname=172.16.10.60

no_master=1

[root@host3 mha]# masterha_check_ssh --conf=/etc/mha/app1.conf

[root@host3 mha]# masterha_check_repl --conf=/etc/mha/app1.conf

此時的警告忽略,MHA可以使用--global_conf選項為多個application指定相同的配置

初識MariaDB之7——MHA高可用初識MariaDB之7——MHA高可用

3.啟動并查看MHA

[root@host3 ~]# masterha_manager --conf=/etc/mha/app1.conf  2>&1 &

[root@host3 ~]# masterha_check_status --conf=/etc/mha/app1.conf

app1 (pid:2633) is running(0:PING_OK), master:172.16.10.40

4.模擬master節(jié)點故障

(1)關閉master節(jié)點的MySQL服務

[root@host4 ~]# mysqladmin -uroot shutdown

(2)在Manager節(jié)點查看此時狀態(tài)

[root@host3 ~]# masterha_check_status --conf=/etc/mha/app1.conf

app1 is stopped(2:NOT_RUNNING).

當由node節(jié)點出現(xiàn)故障時MHA會自動關閉,故障節(jié)點恢復后,不會自動啟動

(3)查看Candidate節(jié)點狀態(tài)

MariaDB [(none)]> show slave hosts;

+-----------+------+------+-----------+

| Server_id | Host | Port | Master_id |

+-----------+------+------+-----------+

|     30 |    | 3306 |     20 |

+-----------+------+------+-----------+

MariaDB [(none)]> show global variables like '%read_only%';

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| read_only   | OFF  |

+---------------+-------+

能夠發(fā)現(xiàn)Candidate節(jié)點已經(jīng)升級為Master節(jié)點,并且read_only選項也自動關閉(盡管配置文件中該選項還存在)

(4)slave節(jié)點查看狀態(tài)

MariaDB [(none)]> show slave status \G

*************************** 1. row ***************************

       Slave_IO_State: Waiting for master to send event

         Master_Host: 172.16.10.50

         Master_User: bak

         Master_Port: 3306

        Connect_Retry: 10

       Master_Log_File: mysql-binlog.000004

     Read_Master_Log_Pos: 605

       Relay_Log_File: mysql-relaylog.000002

        Relay_Log_Pos: 532

    Relay_Master_Log_File: mysql-binlog.000004

      Slave_IO_Running: Yes

      Slave_SQL_Running: Yes

5.恢復故障主機

(1)將故障修復后的主機上線

(2)修改my.cnf文件,加入read_only=ON選項

(3)使用mysqldump等備份工具對當前master主機上的數(shù)據(jù)庫進行備份

(4)使用備份在故障主機上恢復,啟動MySQL服務,再指定新的Master主機和binlog,如果宕機的是半同步的master主機,還需要調換半同步的master和slave角色,并且重啟IO_thread

(5)在MHA的manager節(jié)點上重啟MHA

補充說明

MHA檢查復制狀態(tài)時出現(xiàn)如下報錯:

[root@host3 ~]# masterha_check_repl --conf=/etc/mha/app1.conf

Checking if super_read_only is defined and turned on..DBD::mysql::st execute failed: Unknown system variable'super_read_only' at /usr/share/perl5/vendor_perl/MHA/SlaveUtil.pm line 245.

Fri May  4 11:09:28 2018 - [error][/usr/share/perl5/vendor_perl/MHA/MasterMonitor.pm, ln208] Slaves settings check failed!

Fri May  4 11:09:28 2018 - [error][/usr/share/perl5/vendor_perl/MHA/MasterMonitor.pm, ln416] Slave configuration failed.

Fri May  4 11:09:28 2018 - [error][/usr/share/perl5/vendor_perl/MHA/MasterMonitor.pm, ln427] Error happened on checking configurations.  at /usr/bin/masterha_check_repl line 48.

Fri May  4 11:09:28 2018 - [error][/usr/share/perl5/vendor_perl/MHA/MasterMonitor.pm, ln525] Error happened on monitoring servers.

Fri May  4 11:09:28 2018 - [info] Got exit code 1 (Not master dead).

原因是在5.5.56-MariaDB版本中雖然從節(jié)點設置了read_only選項,但是對于管理員權限的用戶這點不生效,所以在MySQL5.6(Mariadb10.1)后新增了super_read_only選項,但當前版本中沒有這個選項,所以報錯。解決辦法是最后將MHA的版本換成mha4mysql-0.56

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網(wǎng)站名稱:初識MariaDB之7——MHA高可用-創(chuàng)新互聯(lián)
鏈接地址:http://chinadenli.net/article46/diiohg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名靜態(tài)網(wǎng)站微信小程序網(wǎng)站維護定制網(wǎng)站企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設