CentOS 7 + keepalived + MySQL 5.7 搭建雙主

環(huán)境

硬件

配置 測試配置
CPU 1.8GHz
內(nèi)存 4GB
核心 4核
帶寬 1000Mb

軟件

  • VMware? Workstation 16 Pro 16.1.1 build-17801498
  • CentOS Linux release 7.6.1810 (Core)
  • Mysql 5.7
  • keepalived-1.3.5-19.el7.x86_64

規(guī)劃

HOST IP 說明
node3 192.168.88.88 主節(jié)點
node4 192.168.88.94 備份節(jié)點
kp虛擬路由 192.168.88.101 vip

雙主環(huán)境搭建

之前搭建了一套mysql一主一備的環(huán)境,過程參考文章《CentOS 7 + MySQL 5.7 搭建一主一備》,備份節(jié)點可以作為主節(jié)點的數(shù)據(jù)備份,也可以作為讀寫分離支持來降低主節(jié)點的性能壓力,但是,如果主節(jié)點發(fā)生故障快耿,備份節(jié)點無法做到自動接管主節(jié)點的業(yè)務(wù)(需要人工或者其他工具輔助切換)。

本次在一主一備的基礎(chǔ)上幸缕,改造一套雙主運行的環(huán)境极舔。

node4

創(chuàng)建slave用戶

mysql -p
# 只讀賦權(quán)
GRANT SELECT ON *.* TO 'slave'@'192.168.88.88' IDENTIFIED BY 'Slave!23';
# 從權(quán)限 賦權(quán)
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.88.88' IDENTIFIED BY 'Slave!23';
# 刷新權(quán)限
FLUSH PRIVILEGES;

配置文件添加如下配置

# 自增id起始值
auto_increment_offset=2
# 每次自增數(shù)字
auto_increment_increment=8

node3

配置node3(slave)指向node4(master)

mysql -p
stop slave;
CHANGE MASTER TO MASTER_HOST='192.168.88.94',MASTER_USER='slave', MASTER_PASSWORD='Slave!23',MASTER_AUTO_POSITION=1;
start slave;
show slave status\G;

配置文件添加如下配置

# 自增id起始值
auto_increment_offset=1
# 每次自增數(shù)字
auto_increment_increment=8

驗證

node3上創(chuàng)建表t_test3

use db_test;

create table t_test3(
    i_id int auto_increment not null ,
    c_name varchar(8),
    constraint t_test3_pk primary key (i_id)
);

show tables;

node4上看見t_test3

use db_test;
show tables;
node4上的t_test3

node4上創(chuàng)建表t_test2

create table t_test2(
    i_id int auto_increment not null ,
    c_name varchar(8),
    constraint t_test2_pk primary key (i_id)
);

show tables;

node3上看見t_test2

use db_test;
show tables;
node3上的t_test2

node3上插入t_test2表一條數(shù)據(jù)

insert into t_test2 (c_name)  value ('aaa');
select i_id,c_name from t_test2;

node4中可見

node4中的數(shù)據(jù)

node4上插入t_test2表一條數(shù)據(jù)

insert into t_test2 (c_name)  value ('bbb');
select i_id,c_name from t_test2;

node3中可見

node3中的數(shù)據(jù)

至此凤覆,雙主節(jié)點的mysql環(huán)境已經(jīng)全部完成了。

keepalived搭建

kp的安裝和配置過程可以參考之前文章《CentOS7+Keepalived+Nginx高可用配置

其中的nginx驗活腳本改為mysql驗活腳本

check_msql.sh

#!/bin/bash
if [ "$(ps -ef | grep "/usr/sbin/mysqld"| grep -v grep )" == "" ];
then 
    systemctl start mysqld.service
    sleep 30 
    if [ "$(ps -ef | grep "/usr/sbin/mysqld"| grep -v grep )" == "" ];
    then
        systemctl stop keepalived
    fi
fi

node3配置文件

! Configuration File for keepalived

global_defs
{
    notification_email {
        acassen@firewall.loc
        failover@firewall.loc
        sysadmin@firewall.loc
    }
    notification_email_from Alexandre.Cassen@firewall.loc
    smtp_server 127.0.0.1
    smtp_connect_timeout 30
    router_id LVS_DEVEL
    vrrp_skip_check_adv_addr
    vrrp_strict
    vrrp_garp_interval 0
    vrrp_gna_interval 0
    script_user root
    enable_script_security
}

vrrp_script mysql_check
{
    script "/joinway/tools/keepalived/check_msql.sh"
    interval 1
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass joinway
    }
    virtual_ipaddress {
        192.168.88.101
    }
    track_script {
        mysql_check
    }
    notify_master /joinway/tools/keepalived/master.sh
    notify_backup /joinway/tools/keepalived/backup.sh
    notify_fault /joinway/tools/keepalived/fault.sh
    notify_stop /joinway/tools/keepalived/stop.sh
}

node4配置文件

! Configuration File for keepalived

global_defs {
   notification_email {
     acassen@firewall.loc
     failover@firewall.loc
     sysadmin@firewall.loc
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
   vrrp_skip_check_adv_addr
   vrrp_strict
   vrrp_garp_interval 0
   vrrp_gna_interval 0
   script_user root
   enable_script_security
}

vrrp_script mysql_check {
  script "/joinway/tools/keepalived/check_msql.sh"
  interval 1
  user root
}

vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass joinway
    }
    virtual_ipaddress {
        192.168.88.101
    }
    track_script {
        mysql_check
    }
    notify_master /joinway/tools/keepalived/master.sh
    notify_backup /joinway/tools/keepalived/backup.sh
    notify_fault /joinway/tools/keepalived/fault.sh
    notify_stop /joinway/tools/keepalived/stop.sh

}

驗證

kp服務(wù)狀態(tài)正常

通過vip連接數(shù)據(jù)

vip正常

模擬node3掛了

node3掛了

node4接管服務(wù)

vip正常

插入一條數(shù)據(jù)拆魏,從自增id可以看出是node4插入的盯桦。

node4插入一條數(shù)據(jù)

node3恢復(fù)

node3恢復(fù)

vip連接正常

vip連接正常

插入2條數(shù)據(jù),從自增可以看出渤刃,node3已經(jīng)接管

node3插入數(shù)據(jù)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末拥峦,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子卖子,更是在濱河造成了極大的恐慌略号,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洋闽,死亡現(xiàn)場離奇詭異璃哟,居然都是意外死亡,警方通過查閱死者的電腦和手機喊递,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門随闪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人骚勘,你說我怎么就攤上這事铐伴〈樽啵” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵当宴,是天一觀的道長畜吊。 經(jīng)常有香客問我,道長户矢,這世上最難降的妖魔是什么玲献? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮梯浪,結(jié)果婚禮上捌年,老公的妹妹穿的比我還像新娘。我一直安慰自己挂洛,他們只是感情好礼预,可當(dāng)我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著虏劲,像睡著了一般托酸。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上柒巫,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天励堡,我揣著相機與錄音,去河邊找鬼堡掏。 笑死应结,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的布疼。 我是一名探鬼主播摊趾,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼游两!你這毒婦竟也來了砾层?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤贱案,失蹤者是張志新(化名)和其女友劉穎肛炮,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宝踪,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡侨糟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了瘩燥。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秕重。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖厉膀,靈堂內(nèi)的尸體忽然破棺而出溶耘,到底是詐尸還是另有隱情二拐,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布凳兵,位于F島的核電站百新,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏庐扫。R本人自食惡果不足惜饭望,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望形庭。 院中可真熱鬧铅辞,春花似錦、人聲如沸碘勉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽渗饮。三九已至尸饺,卻和暖如春蔬捷,著一層夾襖步出監(jiān)牢的瞬間肠鲫,已是汗流浹背牡整。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工次坡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留钩乍,地道東北人辞州。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像寥粹,于是被迫代替她去往敵國和親变过。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容