1. 测试资源准备
VPC环境内
a) ECS HA1: 172.16.0.224
b) ECS HA2: 172.16.0.225
c) EIP: 139.196.75.13
d) HAVIP: 172.16.0.222
data:image/s3,"s3://crabby-images/3c460/3c460d9185c00aa31085d27f72f6b676f37ef7cd" alt="0d8d052f1aa0b7fab049ab381d0e7dfb6e215bbd"
2.Nginx安装
分别在两台ECS中安装Nginx,安装过程不再赘述。
data:image/s3,"s3://crabby-images/b3fb5/b3fb50e16ec14cf275ac729dd2baf3252735de80" alt="82b3610555fed210cc7c4e58f7e158ad9d2024e7"
更改相应的nginx index.html,以便测试时方便识别主机。
data:image/s3,"s3://crabby-images/65b25/65b255d49224a1328049ad2ec9829f9c31d7bd9b" alt="53ec10f3e092d1010c1b795d13cacc07346d6972"
3.keepalived安装
3.1安装依赖包
yum -y install gcc gcc+ gcc-c++
yum install popt-devel openssl openssl-devel libssl-dev libnl-devel popt-devel
3.2 建立kernel的软连接
ln -s /usr/src/kernels/2.6.32-431.23.3.el6.x86_64/ /usr/src/linux
3.3 安装配置keepalived
yum install keepalived
配置keepalived.conf
Keepalived会定期检查服务器的健康情况,并通过VRRP协议互通监控情况(默认为组播方式)。一旦任何一个服务出现故障,Keepalived会广播ARP包告诉大家,这台故障的服务器不再拥有这个虚拟IP,而是另一台健康的资源服务器才是这个虚拟IP的真正归属。这样所有发送给故障服务的请求就发送给另外一台资源服务器了。
但在阿里云VPC环境中,目前网络环境并不支持VRRP的组播方式,需要将keepalived的通信方式改为单播。
VRRP组播可能导致脑裂,争抢IP,频繁切换,无法连接等情况。典型的错误如下:
data:image/s3,"s3://crabby-images/57d20/57d209678da62a47ad0006f27851c4b9dbab00ec" alt="928ed3c1c6af7abcee1775cec6873b23ae0800b7"
正确编辑配置文件,需要注意以下几点:
1) 两台机器的vrrp_instance State应根据主备需求,分别设置为MASTER或BACKUP。
2) virtual_ipaddress为绑定的havip,并且需要指定绑定的虚拟网卡(如eth0:1)。
3) 务必使用unicast_src_ip 和unicast_peer,将vrrp通信方式改为单播,否则两台机器无法通信。
4) 注意配置文件中virtual_ipaddress与unicast_src_ip/unicast_peer的顺序,否则会影响互备切换。
data:image/s3,"s3://crabby-images/8343c/8343c2e2c4d7c180fec78e5cde03d29c0c1d3db2" alt="1a9a9ae701d396ca060c3b541eae1db140864381"
同理配置ECS HA2。
完整的keepalived.conf配置文件如下所示(文件路径:/etc/keepalived/keepalived.conf):
####主服务器配置文件##########
! 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 192.168.200.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}
vrrp_instance VI_1 {
state MASTER
interface eth0
virtual_router_id 51
priority 120
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
172.16.0.222/16 dev eth0 label eth0:1
}
unicast_src_ip 172.16.0.224
unicast_peer {
172.16.0.225
}
}
virtual_server 172.16.0.222 80 {
delay_loop 6
lb_algo rr
lb_kind NAT
nat_mask 255.255.0.0
persistence_timeout 50
protocol TCP
real_server 172.16.0.224 80 {
weight 1
TCP_CHECK {
connect_timeout 10
nb_get_retry 3
delay_before_retry 3
connect_port 80
}
}
}
#######备服务器配置文件#########
! 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 192.168.200.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}
vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id 51
priority 120
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
172.16.0.222/16 dev eth0 label eth0:1
}
unicast_src_ip 172.16.0.225
unicast_peer {
172.16.0.224
}
}
virtual_server 172.16.0.222 80 {
delay_loop 6
lb_algo rr
lb_kind NAT
nat_mask 255.255.0.0
persistence_timeout 50
protocol TCP
real_server 172.16.0.225 80 {
weight 1
TCP_CHECK {
connect_timeout 10
nb_get_retry 3
delay_before_retry 3
connect_port 80
}
}
}
4. 绑定HaVIP
在管理控制台把两台ECS分别绑上HAVIP
data:image/s3,"s3://crabby-images/78581/785816529017ba7b0075316d328bea4a396d2702" alt="c79f245654d16bc40f767c7048efdbdc851b18d0"
分别在两台机器上启动nginx和keepalived
# /usr/local/nginx/nginx
#/etc/init.d/keepalived start
此时可看到,绑定资源界面主实例一侧链接线已由虚线变为实线,说明链接成功。
data:image/s3,"s3://crabby-images/f0bae/f0bae7c011abcf177b7d2e0e397365ed239c73f4" alt="669100f5a6986001e24c35c6f68471829ef7f4e0"
在管理控制台中可看到实例i-113xhadtu为主实例,i-11kf0kbv7为备实例。
data:image/s3,"s3://crabby-images/fdd73/fdd73efc3c3e0f1ae128133b38dc8ffbac0624c6" alt="d4217e4ebb88284a0ead75e2def9d714882be65b"
在主实例上,通过ifconfig,可以看到,havip已经被绑定到eth0:1上生效。
data:image/s3,"s3://crabby-images/52c9d/52c9df4f41bea5692d833f791a3dfa8e90233097" alt="f17a7211b00096e01b7b2a40c1201c05f82d3e0a"
5. 绑定EIP
在管理控制台—专有网络—高可用虚拟IP -- 绑定资源界面中,将HaVIP绑上弹性公网EIP。弹性公网与高可用虚拟IP连接线由虚线变为实线,连接成功。
data:image/s3,"s3://crabby-images/50ef1/50ef17379df28d18b7d3e19f1be68c8d458c0a69" alt="7dae12897da8a627776abd2449316e62c3216f93"
6. 测试
1)访问测试,浏览器中访问EIP地址,可见nginx的欢迎界面,且欢迎界面来自HA1。
data:image/s3,"s3://crabby-images/4d6f3/4d6f302eafac677de534bfd902b09760e7b65024" alt="a26d17b2020e4cf2fab5405df1d3cbb47a4f54cc"
2)将i-113xhadtu实例关机
data:image/s3,"s3://crabby-images/0b9dc/0b9dc601df5d35839b6f4f97baaf2594722fadb8" alt="2c81acf8535d45a8abb99594b84eea2b2c2096c6"
在高可用虚拟IP界面看到,原来的i-113xhadtu实例已经变为备实例,主实例切换为了i-11kf0kbv7。
data:image/s3,"s3://crabby-images/6b8b9/6b8b9956148d3f4f9dff52c9b8abaf5b1c22ba5e" alt="dec25f3fbddee88b3af83864cbf4e0831dc078aa"
同时,图形界面里的绑定的虚实关系也发生变化,实线连到了当前的新主实例i-11kf0kbv7。
data:image/s3,"s3://crabby-images/8ccf5/8ccf560327f45d5a3ec0dab2df04b780644fe58f" alt="9d8dccb4ded5b4dfbe08107804b72203ce57e79f"
3) 仍然访问EIP地址,nginx欢迎界面已切换至HA2实例。
data:image/s3,"s3://crabby-images/00f53/00f5391a6537a7ad0b5b5cbba0441d28b3ede854" alt="259ed286f439d28a724097a16ad230b3f7a88642"
至此,在VPC环境中,利用HaVip+keepalived配置主备双机高可用完成。
7. 小结
由于HaVIP目前还处于有限用户公测阶段,使用时的限制小结如下:
1) 目前VPC中的网络通信不支持多播和广播,只支持单播;在使用keepalived之类的第三方软件实现高可用,需要通过配置文件把通信方式改成单播;
2) 如果是使用keepalived之类的第三方软件, 需要把信条消息的源IP改成ECS的私网IP(而不要用HaVip的私网IP进行心跳检查),否则可能造成脑裂;
3) 如使用HaVip做自建SNAT网关的高可用时,SNAT实例上配置的SNAT规则中,source IP应该是havip的私网IP而不是ECS自己的私网IP。
4) 目前尚不支持利用LVS搭建负责均衡。
5) 目前每个VPC中最多只能同时存在5个havip对象;