博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
FastDFS蛋疼的集群和负载均衡(十七)之解决LVS+Keepalived遇到的问题
阅读量:6419 次
发布时间:2019-06-23

本文共 1476 字,大约阅读时间需要 4 分钟。

###Interesting things

我在配置LVS+Keepalived遇到几个比较棘手的问题,于是乎记录总结一波。

###What did you do today

  • 问题1:首先就是主备lvs开启防火墙之后,主备lvs的eth0节点都会出现虚拟ip192.168.12.100。我之前的方法是关闭主备lvs的防火墙,这种方法貌似不是一种好的解决方式。

1.在防火墙添加VRRP通讯支持引用,命令:iptables -A INPUT -d 224.0.0.18 -j ACCEPT

2.好像防火墙加了这个策略,也不能解决问题,那么我们安装tcpdump,分析一下vrrp的组播情况。安装命令: yum install -y tcpdump
3.查看vrrp的组播情况,tcpdump vrrp -n,很明显的可以看到192.168.12.4和192.168.12.8这2个ip在轮流发送组播信号。而正常的应该是MASTER服务器发送组播,如果BACKUP收不到MASTER的组播信号,那么就判定MASTER宕机了,BACKUP就接收vip。
4.先确定服务器的SElinux是否设置为关闭,查看SElinux的状态,命令:getenforce,Enforcing#强制开启,Permissive#宽容模式,Disabled#关闭。如果是Enforcing强制模式,我就需要关闭。命令:setenforce 0#设置宽容模式,但是这样只在本次生效,重启服务器后将失效。如果需要永久关闭,还需要修改配置文件。sed -i 's/=enforcing/=disabled/g' /etc/sysconfig/selinux
5.进入/etc/sysconfig/目录下的selinux,注释掉SELINUX=targeted
6.我们查看防火墙,看到蛋疼的一幕。 -A INPUT -d 224.0.0.18/32 -j ACCEPT写在-A INPUT -j REJECT --reject-with icmp-host-prohibited后面了,正确的写法应该是写在-A INPUT -j REJECT --reject-with icmp-host-prohibited的前面。我们需要修改过来!
7.现在我们在主lvs和备lvs查看vrrp的组播情况,发现只有192.168.12.4发给192.168.12.8的情况,这就很爽了嘛!
8. 通过ip a 查看各个节点ip情况。发现只有主lvs的eth0节点有vip,备lvs没有。完美解决!

  • 问题2:通过ipvsadm -ln查看lvs以及对应的RealServer信息,但是发现RealServer只有192.168.12.2:80。正常情况下是有192.168.12.3:80和192.168.12.2:80

1.通过/var/log/keepalived.log,发现主lvs连接192.168.12.3:80失败了!

2. 我们来查看nginx1(192.168.12.2)和nginx2(192.168.12.3)的lo:0节点,显示是虚拟ip192.168.12.100,这是没问题的!
3.那我们只能拿出杀手锏了,重启虚拟机。
4.重启后,我们再来看ipvsadm -ln,发现RealServer有192.168.12.2:80和192.168.12.3:80了,美滋滋。

###Summary

路漫漫其修远兮,吾将上下而求索。下一篇LVS+Keepalived双主模式。

转载地址:http://jxlra.baihongyu.com/

你可能感兴趣的文章
PHP那些事儿
查看>>
使用putty远程连接linux
查看>>
【comparator, comparable】小总结
查看>>
计算机常识 - 收藏集 - 掘金
查看>>
MySQL主从复制读写分离及奇怪的问题
查看>>
Spark学习笔记之相关记录
查看>>
Node 版本管理
查看>>
input的行数自动增减
查看>>
.pyc 想到的一些问题
查看>>
k个最大的数及变种小结
查看>>
【5+】跨webview多页面 触发事件(二)
查看>>
微信开源mars源码分析1—上层samples分析
查看>>
技术攻略】php设计模式(一):简介及创建型模式
查看>>
(十五)java多线程之并发集合ArrayBlockingQueue
查看>>
js学习笔记
查看>>
JS学习笔记——闭包
查看>>
MobX
查看>>
Netty 4.1 源代码学习:线程模型
查看>>
Diomidis Spinellis:有效的调试
查看>>
从后端到前端的转变:如何选择框架?
查看>>