本例结合本博另一篇文章 MHA-大杀器实现MYSQL单主宕机时,VIP漂移实现高可用,环境请参考上一篇文章


本例使用keepalived-1.1.20.tar.gz版本




[root@node1 keepalived-1.1.20]# ./configure --sysconf=/etc/ #此项表示设置keepalived的根目录


如果编译报错“configure: error: Popt libraries is required” 则yum -y install popt-devel


[root@node1 keepalived-1.1.20]# make && make install


[root@node1 keepalived]# cp /usr/local/sbin/keepalived /usr/sbin/   #拷贝命令文件



#####################主机的配置文件设置####################


[root@node1 keepalived]# cat /etc/keepalived/keepalived.conf 

! Configuration File for keepalived


global_defs {#全局配置项

   router_id node1#本机标识号,设置全局唯一

}

vrrp_script check_run {#设置检测服务的脚本

script "/root/check_mysql.sh"

interval 1#每隔一秒检测一次

}


vrrp_instance mha {    #定义keepalived组

    state MASTER#定义本机的keepalived状态

    interface eth0#设置监听网卡

    virtual_router_id 100#设置虚拟router-id,所有keepalived的机器都得是一样

    priority 100   #设置权值,master必须高于backup

    advert_int 5#定义master与backup之间同步检查间隔,单位是秒

    track_interface {#设置监听网卡组

eth0

eth1

}

    authentication {#设置keepalived组的验证类型和密码,所有主机须一样

        auth_type PASS

        auth_pass 1111

    }

track_script {#设置服务监测脚本运行

check_run

}

    virtual_ipaddress {#设置VIP

        10.2.16.250/24 

    }

}


#####################备机的配置文件设置####################


[root@node2 ~]# cat /etc/keepalived/keepalived.conf 

! Configuration File for keepalived


global_defs {

   router_id node2

}


vrrp_script check_run {

        script "/root/check_mysql.sh"

        interval 1

}


vrrp_instance mha {

    state BACKUP

    interface eth0

    virtual_router_id 100

    priority 99

    advert_int 5

track_interface {

eth0

eth1

}

 track_interface {

        eth0

        eth1

        }

  track_script {

        check_run

        }

    authentication {

        auth_type PASS

        auth_pass 1111

    }

    virtual_ipaddress {

10.2.16.250/24

    }

}



mysql服务检测脚本内容,按需修改:


[root@node2 ~]# cat check_mysql.sh 

#!/bin/bash

MYSQL=/usr/bin/mysql

MYSQL_HOST=127.0.0.1

MYSQL_USER=root

MYSQL_PASSWORD=123456

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 -e "show status;" --password=123456 >/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

     pkill keepalived

exit 1

fi

sleep 1

done



启动Keepalived:


[root@node1 ~]#service keepalived start


启动日志:

[root@node1 ~]# tail -f /var/log/messages

Jun 27 11:48:47 node2 Keepalived: Starting VRRP child process, pid=21545

Jun 27 11:48:47 node2 Keepalived_vrrp: Registering Kernel netlink reflector

Jun 27 11:48:47 node2 Keepalived_vrrp: Registering Kernel netlink command channel

Jun 27 11:48:47 node2 Keepalived_vrrp: Registering gratutious ARP shared channel

Jun 27 11:48:47 node2 Keepalived_vrrp: Opening file '/etc/keepalived/keepalived.conf'.

Jun 27 11:48:47 node2 Keepalived_vrrp: Configuration is using : 65535 Bytes

Jun 27 11:48:47 node2 Keepalived_vrrp: Using LinkWatch kernel netlink reflector...

Jun 27 11:48:47 node2 Keepalived_vrrp: VRRP_Instance(mha) Entering BACKUP STATE

Jun 27 11:48:47 node2 Keepalived_vrrp: VRRP sockpool: [ifindex(2), proto(112), fd(9,10)]

Jun 27 11:48:47 node2 Keepalived_vrrp: VRRP_Script(check_run) succeeded



Jun 27 11:49:03 node2 Keepalived_vrrp: VRRP_Instance(mha) Transition to MASTER STATE

Jun 27 11:49:08 node2 Keepalived_vrrp: VRRP_Instance(mha) Entering MASTER STATE

Jun 27 11:49:08 node2 Keepalived_vrrp: VRRP_Instance(mha) setting protocol VIPs.

Jun 27 11:49:08 node2 Keepalived_vrrp: VRRP_Instance(mha) Sending gratuitous ARPs on eth0 for 10.2.16.250

Jun 27 11:49:13 node2 Keepalived_vrrp: VRRP_Instance(mha) Sending gratuitous ARPs on eth0 for 10.2.16.250



查看 VIP:

[root@node1 ~]# ip addr

1: lo: mtu 16436 qdisc noqueue state UNKNOWN 

    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

    inet 127.0.0.1/8 scope host lo

    inet6 ::1/128 scope host 

       valid_lft forever preferred_lft forever

2: eth0: mtu 1500 qdisc pfifo_fast state UP qlen 1000

    link/ether 00:0c:29:c5:22:55 brd ff:ff:ff:ff:ff:ff

    inet 10.2.16.253/24 brd 10.2.16.255 scope global eth0

inet 10.2.16.250/24 brd 10.2.16.255 scope global eth0

    inet6 fe80::20c:29ff:fec5:2255/64 scope link 

       valid_lft forever preferred_lft forever

3: eth1: mtu 1500 qdisc pfifo_fast state UP qlen 1000

    link/ether 00:0c:29:c5:22:5f brd ff:ff:ff:ff:ff:ff

    inet 10.0.0.1/24 brd 10.0.0.255 scope global eth1

    inet6 fe80::20c:29ff:fec5:225f/64 scope link 

       valid_lft forever preferred_lft forever


  此VIP用ifconfig看不到,但是真实存在的。


##########给keepalived 生成的VIP进行mysql登录授权###########


注意:两台机器都需要执行:


mysql> grant all on *.* to 'root'@'10.2.16.250' identified by '123456';


  

####check_mysql.sh 需要在两台机器上都存在


  

  ###############keepalived+mha+check_mysql运行原理#################

  

  实现VIP飘移,需要将node1的Mysql服务停掉,此时keepalived中运行的脚本会检测mysql,检测到mysql挂了之后,会pkill keepalived

  当BACKUP-keepalived检测到主keepalived挂掉之后,会自动启动VIP,而MHA检测到master的mysql挂掉之后,也会将Master移至BAKCUP上

  此时所有的权限都移至Mysql-backup上,并且他已经成为MASTER,接替宕机的master所有工作,从而实现高可用。