linux配置心跳网络,Linux下配置 Keepalived(心跳检测部署)

首先呢,我想先给你们简单介绍一下什么是keepalived:

html

Keepalived的做用是检测服务器的状态,若是有一台web服务器死机,或工做出现故障,Keepalived将检测到,并将有故障的服务器从系统中剔除,同时使用其余服务器代替该服务器的工做,当服务器工做正常后Keepalived自动将服务器加入到服务器群中,这些工做所有自动完成,不须要人工干涉,须要人工作的只是修复故障的服务器。python

你们了解到Keepalived是什么东西了以后,我们就进入主题。mysql

1.下载nginx

http://www.keepalived.org/download.htmlweb

wget http://www.keepalived.org/software/keepalived-1.2.2.tar.gzsql

2.安装

tar -zxvf keepalived-1.2.2.tar.gz

cd keepalived-1.2.2

./configure --prefix=/home/wangpl/mine/soft/keepalived-1.2.2

make && make installshell

补充: 在你们进行./configure  有的机器会报错,这里为你们提供一个简单的解决方案。bash

1.遇到keepalived执行./configure --prefix=/usr/local/keepalived时报错:configure: error: Popt libraries is required

服务器

解决方法:

yum install popt-devel

安装好popt的开发包。

从新./configure 便可。

!!在完成Keepalived以前 我们须要安装依赖包 防止在接下来安装过程当中出错。

yum install openssl-devel

yum install popt-devel

yum install ipvsadm

yum install libnl*

3.方式

安装到系统,默认的启动脚本里写的是系统路径,因此须要拷贝一些文件到系统目录下

$ cp /home/wangpl/mine/soft/keepalived-1.2.2/etc/rc.d/init.d/keepalived /etc/init.d/

$ cp /home/wangpl/mine/soft/keepalived-1.2.2/sbin/keepalived /usr/sbin/

$ cp /home/wangpl/mine/soft/keepalived-1.2.2/etc/sysconfig/keepalived /etc/sysconfig/

$ mkdir -p /etc/keepalived/

$ cp /home/wangpl/mine/soft/keepalived-1.2.2/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf

4.试用网络

进入目录 进行启动cd /etc/init.d/

启动:sh keepalived start

中止:sh keepalived stop

重启:sh keepalived restart

5.  (主从模式)配置keepalived.conf

global_defs {

notification_email {

root@localhost

}

notification_email_from root@localhost

smtp_server localhost

smtp_connect_timeout 30

router_id  NodeA

}

默认的配置文件中,使用第三方smtp服务器,但这在现实中几乎没有意义(须要验证的缘由),咱们将其指定为localhost, 将通知信息的发送交给本地sendmail服务处理。或者把其内容所有删除掉只留下router_id  NodeA。查阅说明文档得知route_id配置是为了标识当前节点,我将其设置为NodeA。固然两个节点的此项设置可相同,也可不相同。

vrrp_instance VI_1 {

state MASTER   #指定A节点为主节点 备用节点上设置为BACKUP便可

interface eth0   #绑定虚拟IP的网络接口

virtual_router_id 51#VRRP组名,两个节点的设置必须同样,以指明各个节点属于同一VRRP组

priority 100#主节点的优先级(1-254之间),备用节点必须比主节点优先级低

advert_int 1#组播信息发送间隔,两个节点设置必须同样

authentication {   #设置验证信息,两个节点必须一致

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {   #指定虚拟IP, 两个节点设置必须同样

192.168.200.16/24#VIP虚拟IP

192.168.200.17/24#主服务器IP

p;          192.168.200.18/24#从服务器IP

}

}

按一样的方法配置节点B并修改配置文件,可将A节点的配置文件复制到B节点,并修改如下几项:

router_id  NodeB

state   BACKUP

priority   99

其它项没必要修改。

测试及验证:

执行命令 ip a (注意ifconfig命令没法查看到配置的虚拟IP),来查看。

6.(主从模式)脑裂问题

上述主从配置方式存在脑裂的可能,即两个节点实际都处于正常工做状态,可是没法接收到彼此的组播通知,这时两个节点均强行绑定虚拟IP,致使不可预料的后果。

这时就须要设置仲裁,即每一个节点必须判断自身的状态(应用服务状态及自身网络状态),要实现这两点可以使用自定义shell脚本实现,经过周期性地检查自身应用服务状态,并不断ping网关(或其它可靠的参考IP)都可。当自身服务异常、或没法ping通网关,则认为自身出现故障,就应该移除掉虚拟IP(中止keepalived服务便可)。主要借助keepalived提供的vrrp_script及track_script实现:

在keepalived的配置文件最前面加入如下代码,定义一个跟踪脚本:

vrrp_script check_local {#定义一个名称为check_local的检查脚本

script "/usr/local/keepalived/bin/check_local.sh"#shell脚本的路径

interval 5#运行间隔

}

再在

vrrp_instance

配置中加入如下代码使用上面定义的检测脚本:

track_script {

check_local

}

咱们在/usr/local/keepalived/bin/check_local.sh定义的检测规则能够是:

以上的路径及文件是本身定义的。

a.自身web服务故障(超时,http返回状态不是200)

b.没法ping通网关

c.产生以上任何一个问题,均应该移除本机的虚拟IP(中止keepalived实例便可)

但这里有个小问题,若是本机或是网关偶尔出现一次故障,那么咱们不能认为是服务故障。更好的作法是若是连续N次检测本机服务不正常或链接N次没法ping通网关,才认为是故障产生,才须要进行故障转移。另外一方面,若是脚本检测到故障产生,并中止掉了keepalived服务,那么当故障恢复后,keepalived是没法自动恢复的。我以为利用独立的脚本以秒级的间隔检查自身服务及网关链接性,再根据故障状况控制keepalived的运行或是中止。

这里提供一个思路,具体脚本内容请你们根据本身的须要编写便可。

脚本/usr/local/nginx/check_nginx.sh"内容:

#!/bin/bash

if["$(ps -ef | grep "nginx: master process"| grep -v grep )"== "" ]

then

/usr/local/nginx/sbin/nginx

sleep 5

if["$(ps -ef | grep "nginx: master process"| grep -v grep )"== "" ]

then

killall keepalived

fi

fi

//若是以上配置我介绍的不理解的话 你们参考一下实例代码。

vi /etc/keepalived/keepalived.conf

编辑文件(主):

global_defs {

router_id nginx_master

}

#监控服务.NGINX mysql等

vrrp_script chk_nginx {

script "/usr/local/nginx/check_nginx.sh"

interval 2

weight 2

}

vrrp_instance VI_1 {

state MASTER

interface eth0

virtual_router_id 51

priority 101

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.xx.xx#VIP(虚拟ip)

192.168.xx.xx#主服务器IP

192.168.xx.xx#从服务器IP

}

track_script {

chk_nginx #检测脚本 上面配置的

}

}

vi /etc/keepalived/keepalived.conf

编辑文件(从):

global_defs {

router_id nginx_backup

}

#监控服务.NGINX mysql等

vrrp_script chk_nginx {

script "/usr/local/nginx/check_nginx.sh"

interval 2

weight 2

}

vrrp_instance VI_1 {

state BACKUP

interface eth0

virtual_router_id 51

priority 99

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.xx.xx#VIP(虚拟ip)

192.168.xx.xx#主服务器IP

192.168.xx.xx#从服务器IP

}

track_script {

chk_nginx #检测脚本 上面配置的

}

}

启动并测试:

1.启动两台机器上的nginx

2.启动两台机器上的keepalived

此时使用命令 ip addr 查看虚拟IP绑定 能够看到主 有,从没有,将主机的keepalived关掉,能够看到vip绑定到了从的上面。

使用其余机器访问使用wget进行访问:vip:xx/wget?userid=20003829

查看是否可以访问,而后让本机的nginx关掉,继续使用wget看是否可以访问,若是可以访问则HA配置成功。

你可能感兴趣的:(linux配置心跳网络)