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

[经验分享] lvs(dr)+keepalived

[复制链接]

尚未签到

发表于 2018-12-29 10:33:13 | 显示全部楼层 |阅读模式
  LVS原理请看:http://ixdba.blog.运维网.com/2895551/552947
  
LVS-MASTER   192.168.100.113
  LVS-BACKUP   192.168.100.116
  REALSERVER1  192.168.100.114
  REALSERVER2  192.168.100.115
  VIP          192.168.100.125
  一. 在LVS-MASTER跟LVS-BACKUP安装keepalived跟ipvsadm,我选择yum安装
  [root@localhost ~]# yum install -y ipvsadm keepalived
  安装完成后配置keepalived
  LVS-MASTER配置:
  [root@localhost ~]# cd /etc/keepalived/
  [root@localhost keepalived]# > keepalived.conf
  [root@localhost keepalived]# vim keepalived.conf
  将此段代码复制进去
  global_defs {
  notification_email {
  edisonchou@hotmail.com
  }
  notification_email_from sns-lvs@gmail.com
  smtp_server 192.168.80.1
  smtp_connection_timeout 30
  router_id LVS_DEVEL  # 设置lvs的id,在一个网络内应该是唯一的
  }
  vrrp_instance VI_1 {
  state MASTER   #指定Keepalived的角色,MASTER为主,BACKUP为备
  interface eth0  #设置对外服务的接口
  virtual_router_id 51  #虚拟路由编号,主备要一致
  priority 100  #定义优先级,数字越大,优先级越高,主DR必须大于备用DR
  advert_int 1  #检查间隔,默认为1s
  authentication {  #设置验证类型和密码,master和buckup一定要设置一样
  auth_type PASS
  auth_pass 1111
  }
  virtual_ipaddress {
  192.168.100.125  #定义虚拟IP(VIP)为192.168.100.125,可多设,每行一个
  }
  }
  # 定义对外提供服务的LVS的VIP以及port
  virtual_server 192.168.100.125 80 {
  delay_loop 6 # 设置健康检查时间,单位是秒
  lb_algo wrr # 设置负载调度的算法为wlc
  lb_kind DR # 设置LVS实现负载的机制,有NAT、TUN、DR三个模式
  nat_mask 255.255.255.0
  persistence_timeout 0     #会话保持时间,单位秒
  protocol TCP
  real_server 192.168.100.114 80 {  # 指定real server1的IP地址
  weight 3   # 配置节点权值,数字越大权重越高
  TCP_CHECK {
  connect_timeout 10     #连接超时时间
  nb_get_retry 3
  delay_before_retry 3
  connect_port 80
  }
  }
  real_server 192.168.100.115 80 {  # 指定real server2的IP地址
  weight 3  # 配置节点权值,数字越大权重越高
  TCP_CHECK {
  connect_timeout 10
  nb_get_retry 3
  delay_before_retry 3
  connect_port 80
  }
  }
  }
  启动keepalived 服务
  [root@localhost ~]# service keepalived start
  正在启动 keepalived:                                      [确定]
  [root@localhost ~]# chkconfig keepalived on
  [root@localhost ~]# chkconfig --list | grep keepalived
  keepalived     0:关闭1:关闭2:启用3:启用4:启用5:启用6:关闭
  LVS-BACKUP配置:
  只需要将LVS-MASTER配置修改两处即可
  state BACKUP   #指定Keepalived的角色,MASTER为主,BACKUP为备
  priority 90  #定义优先级,数字越大,优先级越高,主DR必须大于备用DR
  REALSERVER1跟REALSERVER2 配置
  [root@localhost ~]# vi /etc/rc.d/init.d/realserver     把以下脚本贴到realserver里去      

  #!/bin/bash
#cription: config realserver lo  and  apply noarp

WEB_VIP=192.168.100.125  #虚拟vip,也就是虚拟ip
. /etc/rc.d/init.d/functions

case "$1" in

start)
   ifconfig lo:0 $WEB_VIP netmask 255.255.255.255 broadcast $WEB_VIP
   /sbin/route add -host $WEB_VIP dev lo:0
   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
   echo "1" > /proc/sys/net/ipv4/conf/eth0/arp_ignore
   echo "2" > /proc/sys/net/ipv4/conf/eth0/arp_announce
   echo "1" > /proc/sys/net/ipv4/conf/default/arp_ignore
   echo "2" > /proc/sys/net/ipv4/conf/default/arp_announce
   sysctl -p >/dev/null 2>&1
   echo "RealServer Start OK"
   ;;
stop)
   ifconfig lo:0 down
   route del $WEB_VIP >/dev/null 2>&1
   echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
   echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
   echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
   echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
   echo "0" > /proc/sys/net/ipv4/conf/eth0/arp_ignore
   echo "0" > /proc/sys/net/ipv4/conf/eth0/arp_announce
   echo "0" > /proc/sys/net/ipv4/conf/default/arp_ignore
   echo "0" > /proc/sys/net/ipv4/conf/default/arp_announce
   echo "RealServer Stoped"
   ;;
status)
       # Status of LVS-DR real server.
       islothere=`/sbin/ifconfig lo:0 | grep $WEB_VIP`
       isrothere=`netstat -rn | grep "lo:0" | grep $WEB_VIP`
       if [ ! "$islothere" -o ! "isrothere" ];then
         # Either the route or the lo:0 device
         # not found.
         echo "LVS-DR real server Stopped."
       else
         echo "LVS-DR Running."
       fi
;;
*)
       # Invalid entry.
       echo "$0: Usage: $0 {start|status|stop}"
       exit 1
;;
esac
exit 0
  

  开启服务
  测试------------------------------------------------------------------------------------
  输入192.168.100.125

  刷新一下显示192.168.100.114 配置成功

  

  [root@localhost ~]# service realserver start
  RealServer Start OK
  测试。。。。。。。。。。。。。。。。。。。。。。。。。
  关闭192.168.100.115  REALSERVER2 的nginx 服务器
  LVS-MASTER上 查看日志
  [root@localhost ~]# tail -f /var/log/messages


  然后再开启服务,看看日志

  

  模拟LVS-MASTER 宕机  在LVS-BACKUP 查看日志
  关闭keepalived 服务



  然后开启服务


  





运维网声明 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-657151-1-1.html 上篇帖子: CentOS6.2下搭建LVS(DR)+Keepalived实现高性能高可用负载均衡服务器 下篇帖子: 企业中MySQL高可用集群架构三部曲之MM+keepalived
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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