设为首页 收藏本站
查看: 2476|回复: 0

[经验分享] [高可用]Ubuntu下LVS + Keepalived 实现SuperMap iServer高可用负载均衡实现

[复制链接]

尚未签到

发表于 2015-11-20 09:01:10 | 显示全部楼层 |阅读模式
题记
  前面已经介绍了实现MySQL和RabbitMQ的集群部署,但是一个OpenStack环境的高可用性,简单的说就是任何一个节点的高可用性,每个节点又包括不同的服务和组件,这里面我们先不具体谈及细节,也就是说,先以控制节点为例,我们需要准备多台控制节点,但是前端需要对外暴露出一个VIP,网络节点或者计算节点只需要连接这个VIP即可,那么VIP连接之后,会自动负载到该集群环境下任意一台机器上,行业术语为飘到哪台机器,这次我们就实现一下VIP的环境模拟。
当然,如果你有硬件设备如F5就不需要了解这个了,本篇主要使用软件实现,而且也是非常成熟的LVS+Keepalived来实现。
原理
  LVS是由章文嵩博士在1998年提出的,主要实现虚拟IP,而Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的web服务器从系统中剔除,当web服务器工作正常后Keepalived自动将web服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人工做的只是修复故障的web服务器。主要用作RealServer的健康状态检查以及LoadBalance主机和BackUP主机之间failover的实现。
环境
  本环境并没有对LVS+Keepalived进行主/备搭建,使用单机来实现,后端连接两个SuperMap iSever来进行测试。
  LVS+Keepalived:10.0.0.10   VIP:10.0.0.200

iServer1:10.0.0.11

iServer2:10.0.0.12
部署
  1、在LVS+Keepalived集群上安装相关软件

需要说明的是,如果该机器只安装LVS,需要使用ipvsadm进行配置,但是该环境已经安装了keepalived,只需要修改keepalived.conf配置文件即可。


root@vip:~# apt-get install ipvsadm keepalived
  2、检测LVS安装

安装完毕之后,输入ipvsadm,弹出如下信息说明安装成功


root@vip:~# ipvsadm
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
-> RemoteAddress:Port           Forward Weight ActiveConn InActConn
  3、修改/etc/keepalived/keepalived.conf配置文件,如果没有,添加即可


global_defs {
router_id LVS_DEVEL
}
vrrp_instance VI_1 {
state MASTER  #如果使用主/备,另外一台机器需要设置为BACKUP
interface eth0 #检测网络端口
virtual_router_id 51 #主备的虚拟机路由ID必须一致
priority 150   #主备的优先级,主优先级要大于备
advert_int 1       #VRRP Multicast广播周期秒数
authentication {
auth_type PASS  # VRRP认证方式
auth_pass 1111   # VRRP口令字
}
virtual_ipaddress {
10.0.0.200  # 如果有多个VIP,继续换行填写
}
}
#iServer的监听端口为8090
virtual_server 10.0.0.200 8090{
delay_loop 1       # 每隔1秒查询realserver状态
lb_algo wrr          # lvs 算法
lb_kind DR          # Direct Route
protocol TCP       # 用TCP协议检查realserver状态
#第一台iserver物理环境
real_server 10.0.0.11 8090{
weight 3   
TCP_CHECK {
connect_timeout 10
nb_get_retry 3
delay_before_retry 3
connect_port 8090
}
}
#第二台iserver物理环境
real_server 10.0.0.12 8090 {
weight 3   
TCP_CHECK {
connect_timeout 10
nb_get_retry 3
delay_before_retry 3
connect_port 8090
}
}
}
  4、重启keepalived服务,然后再次检查ipvsadm


root@vip:~# ipvsadm
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
-> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  10.0.0.200:8090 wrr
-> ubuntu:8090                  Route   3      0          0         
  -> ubuntu2:8090                 Route   3      0          0   
  5、这时候,可以测试使用其他机器是否可以ping通LVS机器的物理IP和虚拟IP。

6、检查iserver1和iserver2的服务状态和连接manager是否正常。

7、对两台iserver机器/etc/rc.local添加配置信息,然后重启


ifconfig eth0:0 10.0.0.200 netmask 255.255.255.0 broadcast 10.0.0.255 up
route add -host 10.0.0.200 dev eth0:0
echo "0" > /proc/sys/net/ipv4/ip_forward
echo "1" > /proc/sys/net/ipv4/conf/lo/arp_ignore
echo "2" > /proc/sys/net/ipv4/conf/lo/arp_announce
echo "1" > /proc/sys/net/ipv4/conf/all/arp_ignore
echo "2" > /proc/sys/net/ipv4/conf/all/arp_announce
  8、重启之后确保每台iserver的机器的服务和manager都是正常的。
测试
  为了区分使用VIP连接,能够飘到不同的iserver机器上,我分别对不同机器的服务创建的不一样。

iserver1:10.0.0.11

DSC0000.jpg
  iserver2:10.0.0.12

DSC0001.jpg
  然后使用虚拟机IP进行连接

DSC0002.jpg
  同样的URL,多刷新几次

DSC0003.jpg

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-141349-1-1.html 上篇帖子: [高可用]Ubuntu下Haproxy + Keepalived 实现SuperMap iServer高可用负载均衡实现(2) 下篇帖子: Mysql 5.6 双主互备高可用(Keepalived+mysql) (二)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表