1
2
3
|
[root@node1 ~]# cd /etc/keepalived/
[root@node1 keepalived]# cp keepalived.conf keepalived.conf.back
//先给配置文件备份一下
[root@node1 keepalived]# vim keepalived.conf
|
1
2
3
4
5
6
7
8
9
|
global_defs {
notification_email {
//定义邮件服务的
root@localhost
//定义收件人,这里改为本机,只是测试使用
}
notification_email_from kaadmin@localhost
//定义发件人,
smtp_server
127.0
.
0.1
//定义邮件服务器,一定不能使用外部地址
smtp_connect_timeout
30
//超时时间
router_id LVS_DEVEL
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
vrrp_instance VI_1 {
//定义虚拟路由,VI_1 为虚拟路由的标示符,自己定义名称
state MASTER
//开启后,该节点的优先级比另一节点的优先级高,所以转化为MASTER状态
interface
eth0
//所有的通告等信息都从eth0这个接口出去
virtual_router_id
7
//虚拟路由的ID,而且这个ID也是虚拟MAC最后一段的来源,这个ID号一般不能大于255,且这个ID一定不能有冲突
priority
100
//初始优先级
advert_int
1
//通告的个数
authentication {
//认证机制
auth_type PASS
//认证类型
auth_pass
1111
//密码,应该为随机的字符串
}
virtual_ipaddress {
//虚拟地址,即VIP
172.16
.
6.100
}
}
|
1
|
[root@node1 keepalived]# scp keepalived.conf
172.16
.
6.1
:/etc/keepalived/
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
[root@node2 ~]# cd /etc/keepalived/
[root@node2 keepalived]# vim keepalived.conf
vrrp_instance VI_1 {
state BACKUP
//修改从节点的状态,主节点为MASTER,从节点就为BACKUP
interface
eth0
virtual_router_id
7
priority
99
//修改优先级,注意从节点的优先级一定要小于主节点
advert_int
1
authentication {
auth_type PASS
auth_pass
1111
}
virtual_ipaddress {
172.16
.
6.100
}
}
|
1
2
|
[root@node1 keepalived]# service keepalived start
[root@node1 ~]# ip addr show
//查看我们定义的VIP
|
1
2
|
[root@node1 ~]# service keepalived start
[root@node1 ~]# ip addr show
//检测结果发现VIP转移到了主节点
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
[root@node1 ~]# cd /etc/keepalived/
[root@node1 keepalived]# vim notify.sh
//编写脚本
#!/bin/bash
vip=
172.16
.
6.100
contact=
'root@localhost'
thisip=`ifconfig eth0 | awk
'/inet addr:/{print $2}'
| awk -F:
'{print $2}'
`
Notify() {
mailsubject=
"$thisip is to bi $vip master"
mailbody=
"vrrp transaction, $vip floated to $thisip"
echo $mailbody | mail -s
"$mailsubject"
$contact
}
case
"$1"
in
master)
notify master
exit
0
;;
backup)
notify backup
exit
0
;;
fault)
notify fault
exit
0
;;
*)
echo
'Usage: `basename $0` {master|backup|fault}'
exit
1
;;
esac
[root@node1 keepalived]# chmod +x notify.sh
[root@node1 keepalived]# ./notify.sh master
[root@node1 keepalived]# mail
//查看有没有收到通知
Heirloom Mail version
12.4
7
/
29
/
08
. Type ?
for
help.
"/var/spool/mail/root"
:
1
message
1
new
>N
1
root Wed Sep
25
14
:
54
18
/
668
"172.16.6.10 is to bi 172.16.6.100 mas"
&
|
1
2
3
4
5
6
7
8
9
|
[root@node1 keepalived]# ./notify.sh backup
[root@node1 keepalived]# ./notify.sh fault
[root@node1 keepalived]# mail
Heirloom Mail version
12.4
7
/
29
/
08
. Type ?
for
help.
"/var/spool/mail/root"
:
3
messages
2
new
1
root Wed Sep
25
14
:
54
19
/
679
"172.16.6.10 is to bi 172.16.6.100 mas"
>N
2
root Wed Sep
25
14
:
57
18
/
668
"172.16.6.10 is to bi 172.16.6.100 mas"
N
3
root Wed Sep
25
14
:
57
18
/
668
"172.16.6.10 is to bi 172.16.6.100 mas"
&
|
1
|
[root@node1 keepalived]# vim keepalived.conf
|
1
2
3
4
5
|
vrrp_script chk_mantaince_down{
//定义可以手动控制状态的脚本
script
"[[ -f /etc/keepalived/down ]] && exit 1 || exit 0"
interval
1
//检查时间间隔
weight -
2
//如果检测失败,优先级-2
}
|
1
2
3
4
5
6
|
track_script {
//引用定义的脚本
chk_mantaince_down
}
notify_master
"/etc/keepalived/notify.sh master"
notify_backup
"/etc/keepalived/notify.sh backup"
notify_fault
"/etc/keepalived/notify.sh fault"
|
1
|
[root@node1 keepalived]# scp notify.sh
172.16
.
6.1
:/etc/keepalived/
|
1
|
root@node1 keepalived]# touch down
|
1
2
|
[root@node1 keepalived]# tail -f /
var
/log/messages
You have
new
mail
in
/
var
/spool/mail/root
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
[root@node1 keepalived]# vim keepalived.conf
#####负载均衡阶段#################
virtual_server
172.16
.
6.100
80
{
//指定VIP和端口
delay_loop
6
//延迟多少个周期再启动服务,做服务检测
lb_algo rr loadbalance 负载均衡调度算法
lb_kind DR 类型
nat_mask
255.255
.
0.0
掩码
persistence_timeout
0
持久连接时间
protocol TCP
//协议
real_server
172.16
.
6.11
80
{
//定义后端realserver的属性
weight
1
HTTP_GET {
//定义检测的方法
url {
//检测的URL
path /
status_code
200
//获取结果的状态码
}
connect_timeout
3
//连接超时时间
nb_get_retry
3
//尝试次数
delay_before_retry
3
//每次尝试连接的等待时间
}
}
real_server
172.16
.
6.12
80
{
//定义后端realserver的属性
weight
1
HTTP_GET {
//定义检测的方法
url {
//检测的URL
path /
status_code
200
//获取结果的状态码
}
connect_timeout
3
//连接超时时间
nb_get_retry
3
//尝试次数
delay_before_retry
3
//每次尝试连接的等待时间
}
}
}
|
1
2
3
4
5
6
7
|
[root@node1 keepalived]# service keepalived restart
[root@node1 keepalived]# ipvsadm -L -n
IP Virtual Server version
1.2
.
1
(size=
4096
)
Prot LocalAddress:Port Scheduler Flags
-> RemoteAddress:Port Forward Weight ActiveConn InActConn
TCP
172.16
.
6.100
:
80
rr
[root@node1 keepalived]#
|
1
2
3
4
5
6
|
#ifconfig lo:
0
172.16
.
6.11
broadcast
172.16
.
6.11
netmask
255.255
.
255.255
up
#route add -host
172.16
.
6.11
dev lo:
0
#echo
1
> /proc/sys/net/ipv4/conf/lo/arp_ignore
#echo
1
> /proc/sys/net/ipv4/conf/all/arp_ignore
#echo
2
> /proc/sys/net/ipv4/conf/all/arp_announce
#echo
2
> /proc/sys/net/ipv4/conf/lo/arp_announce
|
1
2
3
4
|
[root@node1 ~]# vim /usr/share/nginx/html/index.html
//节点1
172.16
.
6.10
[root@node2 ~]# vim /usr/share/nginx/html/index.html
//节点2
172.16
.
6.1
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
[root@node1 keepalived]# vim notify.sh
//修改脚本,让它可以监测nginx服务,并可以启动或关闭服务
##################
case
"$1"
in
master)
notify master
/etc/rc.d/init.d/nginx start
exit
0
;;
backup)
notify backup
/etc/rc.d/init.d/nginx stop
exit
0
;;
fault)
notify fault
/etc/rc.d/init.d/nginx stop
exit
0
;;
######################################
|
1
|
[root@node1 keepalived]# scp notify.sh
172.16
.
6.1
:/etc/keepalived/
|
1
2
3
4
|
[root@node1 keepalived]# touch down
[root@node1 keepalived]#ss -tunl
//发现80端口未被监听
[root@node1 keepalived]# rm -f down
[root@node1 keepalived]#ss -tunl
//发现80端口已经被监听
|