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

[经验分享] Linux下安装配置使用 Keepalived

[复制链接]

尚未签到

发表于 2018-12-29 09:19:46 | 显示全部楼层 |阅读模式
  1.下载
  http://www.keepalived.org/download.html
  或
  wget http://www.keepalived.org/software/keepalived-1.2.2.tar.gz
  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 install
  3.方式,以下两种方式可选其一
  3.1安装到系统,默认的启动脚本里写的是系统路径,所以需要拷贝一些文件到系统目录下
  $ 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
  3.2绿色方式(推荐学习使用)
  不用拷贝到系统文件,只需要修改下启动脚本即可,将原来的写死的系统路径改为相对路径就好了,我的配置如下:
  a.将二进制的keepalived放到了bin目录
  b.将keepalived.conf放到了conf目录
  c.将脚本(启动停止等)放到了根目录
  结构如下图:

  4.试用
  启动:sh keepalived start
  停止:sh keepalived stop
  重启:sh keepalived restart
  5.其实真正起作用的是那个keepalived二进制文件,它可以通过 -f 参数指定配置文件参数,停止的时候直接 kill 或 pkill 或killall掉就可以,如果直接使用keepalived二进制文件启动和停止的话可以方便地更换配置文件。
  PS:需要 Root权限 运行keepalived
  6.(主从模式)配置keepalived.conf
  [javascript] view plain copy

  •   global_defs {
  •   notification_email {
  •   root@localhost
  •   }
  •   notification_email_from root@localhost
  •   smtp_server localhost
  •   smtp_connect_timeout 30
  •   router_id  NodeA
  •   }
  默认的配置文件中,使用第三方smtp服务器,但这在现实中几乎没有意义(需要验证的原因),我们将其指定为localhost, 将通知信息的发送交给本地sendmail服务处理。查阅说明文档得知route_id配置是为了标识当前节点,我将其设置为NodeA。当然两个节点的此项设置可相同,也可不相同。
  [javascript] view plain copy

  •   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
  •   192.168.200.17 /24
  •   192.168.200.18 /24
  •   }
  •   }
  按同样的方法配置节点B并修改配置文件,可将A节点的配置文件复制到B节点,并修改以下几项:
  router_id  NodeB
  state   BACKUP
  priority   99
  其它项不必修改。
  测试及验证:
  执行命令 ip a (注意ifconfig命令无法查看到配置的虚拟IP),可以看到节点A已经绑定了16/17/18的ip,此时,拔掉节点A的网线,在节点B上上执行ip a就发现虚拟IP已经绑定到节点B上,再恢复A节点的网线,虚拟IP又绑定回节点A之上。
  7.(主从模式)脑裂问题
  上述主从配置方式存在脑裂的可能,即两个节点实际都处于正常工作状态,但是无法接收到彼此的组播通知,这时两个节点均强行绑定虚拟IP,导致不可预料的后果。
  这时就需要设置仲裁,即每个节点必须判断自身的状态(应用服务状态及自身网络状态),要实现这两点可使用自定义shell脚本实现,通过周期性地检查自身应用服务状态,并不断ping网关(或其它可靠的参考IP)均可。当自身服务异常、或无法ping通网关,则认为自身出现故障,就应该移除掉虚拟IP(停止keepalived服务即可)。主要借助keepalived提供的vrrp_scripttrack_script实现:
  在keepalived的配置文件最前面加入以下代码,定义一个跟踪脚本:
  [javascript] view plain copy

  •   vrrp_script check_local { #定义一个名称为check_local的检查脚本
  •   script "/usr/local/keepalived/bin/check_local.sh" #shell脚本的路径
  •   interval 5  #运行间隔
  •   }
  再在vrrp_instance配置中加入以下代码使用上面定义的检测脚本:
  [javascript] view plain copy

  •   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的运行或是停止。
  这里提供一个思路,具体脚本内容请大家根据自己的需要编写即可。
  8.(示例)nginx + keepalived 实现HA 主从模式
  vi /etc/keepalived/keepalived.conf
  编辑文件(主):
  [javascript] view plain copy

  •   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.1.254
  •   }
  •   track_script {
  •   chk_nginx  #检测脚本 上面配置的
  •   }
  •   }
  vi /etc/keepalived/keepalived.conf
  编辑文件(从):
  [javascript] view plain copy

  •   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.1.254
  •   }
  •   track_script {
  •   chk_nginx  #检测脚本 上面配置的
  •   }
  •   }
  脚本/usr/local/nginx/check_nginx.sh"内容:
  [javascript] view plain copy

  •   #!/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
  启动并测试:
  1.启动两台机器上的nginx
  2.启动两台机器上的keepalived
  此时使用命令 ip addr 查看虚拟IP绑定 可以看到主 有,从没有,将主机的keepalived关掉,可以看到vip绑定到了从的上面
  使用其他机器访问使用wget进行访问:vip:xx/wget ?userid=20003829
  查看是否能够访问,然后让本机的nginx关掉,继续使用wget看是否能够访问,如果能够访问则HA配置成功。
  本文出自http://blog.csdn.net/conquer0715/article/details/47955553


运维网声明 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-657080-1-1.html 上篇帖子: haproxy+keepalived应用实战 下篇帖子: CentOS 7 部署LVS集群(DR模式、NAT模式,LVS+keepalived)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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