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

[经验分享] Lvs+Keepalived负载均衡方案

[复制链接]

尚未签到

发表于 2015-9-4 10:45:37 | 显示全部楼层 |阅读模式
  之前做的负载均衡,有需要的可以看一下。
  这里列几个刚开始接触lvs时比较模糊的概念:
  LVS: Linux 虚拟服务器(Linux Virtual Server)是一组用来在真实服务器间平衡 IP 负载的整合软件组件,在linux2.4以后,LVS已经是linux内核的一部分。
  IPVS:IP虚拟服务器(IP Virtual Server)是运行在LVS下的提供负载平衡功能的一种技术。
  ipvsadm:ipvs的一个客户端工具。
  keepalived:是VRRP协议的完美实现,keepalived 采用了多进程的设计模式,一般我们可以看到VRRP子进程,healthchecker子进程,Keepalived里面对LVS的相关操作并不直接使用ipvsadm这样的客户端程序,而是直接使用IPVS提供的函数进程操作。
  
  实战:业务场景:提供多组服务的负载均衡。
  举个栗子,应用服务器1、2、3提供相同的服务A,应用服务器4、5、6提供相同的服务B,通过两台LVS(一主一备)将客户端访问负载到这六台服务器上,其中服务A和服务B必须通过端口来区分开来。
  这里给出的步骤是我每实践一步就记录下来的:
  LVS服务器:
  1)安装ipvsadm   (用于查看ipvs的分发情况)

yum install ipvsadm

2)安装keepalived

1,tar zxf keepalived-1.1.16.tar.gz
2,yum install gcc, openssl, openssl-devel,popt-devel
3,./configure --prefix=/usr --sysconf=/etc
4,make && make install

  5,修改防火墙 -A INPUT -i eth1 -p vrrp -s 10.92.21.57 -j ACCEPT   (打开healthchecker检查防火墙)

  6,修改防火墙 -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT (打开服务防火墙端口)

3)配置keepalived.conf(说明:这里的VIP是10.92.1.141,服务1是分发到10.92.1.197和15的3306端口,服务2是分发到10.92.1.15的9083端口)
  ! Configuration File for keepalived
  global_defs {
   notification_email {
     zengqingwei@csair.com
   }
   notification_email_from zengqingwei@csair.com
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id lnmp_node1
}
  vrrp_sync_group VG_1 {
group {
mysql
}
}
  vrrp_instance mysql {
    state MASTER
    interface eth1
    virtual_router_id 51
    priority 150
    advert_int 1
    virtual_ipaddress {
        10.92.1.141  #VIP
    }
    authentication {
auth_type PASS
auth_pass fsaf..7&f
}
notify_master /opt/to_master.sh #LVS抢到主时调用此脚本
notify_backup /opt/to_backup.sh #LVS转成备时调用此脚本
notify_fault  /opt/to_fault.sh #LVS故障时调用此脚本
    notify_stop   /opt/to_stop.sh #LVS停止时调用此脚本
}
  virtual_server 10.92.1.141 3306 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    nat_mask 255.255.255.0
    protocol TCP
  real_server 10.92.1.197 3306 {
        weight 3            
        TCP_CHECK {
        connect_timeout 10   
        #nb_get_retry 3
        #delay_before_retry 3
        #connect_port 3306
        }
    }
   
    real_server 10.92.1.15 3306 {
        weight 3            
        TCP_CHECK {
        connect_timeout 10   
        #nb_get_retry 3
        #delay_before_retry 3
        #connect_port 3306
        }
    }
}
  virtual_server 10.92.1.141 9083 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    nat_mask 255.255.255.0
    protocol TCP
   
    real_server 10.92.1.15 9083 {
        weight 3            
        TCP_CHECK {
        connect_timeout 10   
        #nb_get_retry 3
        #delay_before_retry 3
        #connect_port 3306
        }
    }
}


4)相关命令
service keepalived start/stop  keepalived启动停止
ipvsadm   查看ipvs的负载情况

  

RS服务器分为linux和windows两种情况:
1)linux:


ifconfig lo:0 ${VIP} broadcast ${VIP} netmask 255.255.255.255 up
vi /etc/sysctl.conf
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
sysctl -p

2)windows


安装microsoft loopback adapter:
cmd
hdwwiz.exe
查看网络适配器 是否有microsoft loopback adapter(如果没有的需要自己去安装哟):
DSC0000.png
cmd运行下面的命令即可
netsh interface ipv4 set interface "本地连接" weakhostreceive=enabled
netsh interface ipv4 set interface "本地连接" weakhostsend=enabled
netsh interface ipv4 set interface "loopback" weakhostreceive=enabled
netsh interface ipv4 set interface "loopback" weakhostsend=enabled

运维网声明 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-109299-1-1.html 上篇帖子: nginx+keepalived配置双主高可用负载均衡 下篇帖子: keepalived+MySQL双主实现高可用性
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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