歡迎您光臨本站 註冊首頁

Keepalived+mysql 自動切換

←手機掃碼閱讀     火星人 @ 2014-03-03 , reply:0

Keepalived+mysql 自動切換

Keepalived+mysql 自動切換


Keepalived+mysql 自動切換
網路結構:
VIP 192.168.20.50
mysq11 192.168.20.37 主
mysql2 192.168.20.38 備

一 mysql 主主同步
二 安裝keepalived
三 keepalived 主備配置文件
四 mysql狀態檢測腳本/root/bin/keepalived_check_mysql.sh
五 防火牆設置
六 測試及診斷
七 參考資料
注 keepalived之間使用vrrp組播方式通信使用的IP地址是224.0.0.18

一 mysql 主主同步
請百度谷歌。
二 安裝keepalivedwget http://www.keepalived.org/software/keepalived-1.2.2.tar.gz

tar zxvf keepalived-1.2.2.tar.gz

cd keepalived-1.2.2

./configure --prefix=/

make

make install
複製代碼三 keepalived 主備配置文件
主備置文件不同處有 state  nopreempt priority 參考資料里有詳細說明作用
192.168.20.37 主配置vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived

global_defs {

   router_id 9ai9.net

}

vrrp_script check_run {

   script "/root/keepalived_check_mysql.sh"

   interval 5

}

vrrp_sync_group VG1 {

    group {

          VI_1

    }

}

vrrp_instance VI_1 {

    state MASTER

    interface eth0

    virtual_router_id 88

    priority 100

    advert_int 1

    nopreempt

    authentication {

        auth_type PASS

        auth_pass 9ai9.net

    }

    track_script {

        check_run

    }

    virtual_ipaddress {

        192.168.20.50

    }

}
複製代碼192.168.20.38 備用配置文件

vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived

global_defs {

   router_id 9ai9.net

}

vrrp_script check_run {

   script "/root/keepalived_check_mysql.sh"

   interval 5

}

vrrp_sync_group VG1 {

    group {

          VI_1

    }

}

vrrp_instance VI_1 {

    state BACKUP

    interface eth0

    virtual_router_id 88

    priority 80

    advert_int 1

    authentication {

        auth_type PASS

        auth_pass 9ai9.net

    }

    track_script {

        check_run

    }

   

    virtual_ipaddress {

        192.168.20.50

    }

}
複製代碼四 mysql狀態檢測腳本/root/bin/keepalived_check_mysql.shvim  /root/keepalived_check_mysql.sh

#!/bin/bash

MYSQL=/usr/local/mysql/bin/mysql

MYSQL_HOST=localhost

MYSQL_USER=root

MYSQL_PASSWORD=9ai9.net

CHECK_TIME=3

#mysql  is working MYSQL_OK is 1 , mysql down MYSQL_OK is 0

MYSQL_OK=1

function check_mysql_helth (){

    $MYSQL -h $MYSQL_HOST -u $MYSQL_USER -p${MYSQL_PASSWORD} -e "show status;" >/dev/null 2>&1

    if [ $? = 0 ] ;then

    MYSQL_OK=1

    else

    MYSQL_OK=0

    fi

    return $MYSQL_OK

}

while [ $CHECK_TIME -ne 0 ]

do

    let "CHECK_TIME -= 1"

   

    check_mysql_helth

if [ $MYSQL_OK = 1 ] ; then

    CHECK_TIME=0

    exit 0

fi

if [ $MYSQL_OK -eq 0 ] &&  [ $CHECK_TIME -eq 0 ]

then

    /etc/init.d/keepalived stop

    exit 1

fi

sleep 1

done
複製代碼賦予執行許可權

chmod 755 /root/keepalived_check_mysql.sh
複製代碼
五 防火牆設置
vrrp協議 使用224.0.0.18地址組播
iptables -I RH-Firewall-1-INPUT  -d 224.0.0.18 -j ACCEPT

六 測試及工具
故障前遊客,如果您要查看本帖隱藏內容請回復
故障切換
遊客,如果您要查看本帖隱藏內容請回復
可以用同網段的另一台伺服器 arping 1 這個虛擬IP
看看對應該的MAC地址 可以知道虛擬IP對應的真實伺服器

配置文件 不正確時 有時候日誌會有以下提示
VRRP_Instance(VI_1) Now in FAULT state

advert_int 兩台keepalived 這個參數 不一致時 日誌會有以下提示
Keepalived_vrrp: advertissement interval mismatch mine=5000000 rcved=1

七 參考資料

keepalived 官網 http://www.keepalived.org/index.html
田老 http://www.keepalived.org/sery-lvs-cluster.pdf
Linuxtone http://docs.linuxtone.org/ebooks/LoadBalance/lvs/keepalived%20the%20definitive%20guide--FinalBSD.pdf
虛擬路由器冗餘協議 http://baike.baidu.com/view/876125.htm
組播 http://baike.baidu.com/view/492256.htm
《解決方案》

謝謝分享

[火星人 ] Keepalived+mysql 自動切換已經有398次圍觀

http://coctec.com/docs/service/show-post-1165.html