搭建LVS+Keepalived负载均衡集群

学习了LVS+Keepalived负载均衡的搭建,网上的教程很多,但是动起手来遇到不少问题。

现在把自己的搭建过程以及遇到的一些问题给分享下。

硬件环境:

Macbook 8G内存,250G SSD,双核

软件环境:

由于资源有限,搭建了4个虚拟机。

虚拟机

[root@rs-1 work]# uname -a

Linux rs-1 2.6.18-238.el5 #1 SMP Thu Jan 13 15:51:15 EST 2011 x86_64 x86_64 x86_64 GNU/Linux

[root@rs-1 work]# cat /etc/RedHat-release

CentOS release 5.6 (Final)

4个虚拟机的ip地址分配如下:

Master DR: { ip: 172.16.3.89 hostname: lvs-backup}

Slave DR: { ip:172.16.3.90 hostname:lvs}

Real Server1: {ip: 172.16.3.91 hostname: rs-1}

Real Server2: { ip:172.16.3.92 hostname: rs-2}

VIP: 172.16.3.199

1.在Master DR和Slave DR分别安装ipvsadm(1.24), keepalived(1.2.12)

安装ipvsadm

检查系统是否安装了IPVS模块,下图显示系统已经支持ipvs模块的。

[root@lvs ~]# modprobe -l | grep ipvs

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_dh.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_ftp.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_lblc.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_lblcr.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_lc.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_nq.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_rr.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_sed.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_sh.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_wlc.ko

/lib/modules/2.6.18-238.el5/kernel/net/ipv4/ipvs/ip_vs_wrr.ko

做个软连接

[vagrant@lvs src]$ sudo ln -s /usr/src/kernels/2.6.18-238.el5-x86_64/ /usr/src/linux

编译

[vagrant@lvs ipvsadm-1.24]$ make

安装

[vagrant@lvs ipvsadm-1.24]$ sudo make install

检测是否安装成功

[root@lvs ~]# ipvsadm -v

ipvsadm v1.24 2005/12/10 (compiled with getopt_long and IPVS v1.2.1)
能打印出版本号说明已经安装成功了!!!!

安装keepalived

configure

[vagrant@lvs keepalived-1.2.12]$./configure --sysconf=/etc --with-kernel-dir=/usr/src/kernels/2.6.18-238.el5-x86_64/

编译

[vagrant@lvs keepalived-1.2.12]$ make

安装

[vagrant@lvs keepalived-1.2.12]$ sudo make install

做个软连接

[vagrant@lvs keepalived-1.2.12]$ sudo ln -s /usr/local/sbin/keepalived /sbin/

检测是否安装成功

[root@lvs ~]# keepalived -v

Keepalived v1.2.12 (05/06,2014)
能打印出版本号,说明安装已经成功了!!

同理在lvs-backup上安装keepalived

检测是否安装成功

[root@lvsbackup~]# keepalived -v

Keepalived v1.2.12 (05/06,2014)

配置keepalived

! Configuration File for keepalived

#global_defs {

#  notification_email {

#设置报警邮件地址,可以设置多个,每行1个,

#需开启邮件报警及本机的Sendmail服务。

#  }

#notification_email_from Alexandre.Cassen@firewall.loc

#smtp_server 192.168.199.1  #设置SMTP Server地址;

#smtp_connect_timeout 30

#router_id LVS_DEVEL

#}

########VRRP Instance########

vrrp_instance VI_1 {

state MASTER    #指定Keepalived的角色,MASTER为主机服务器,BACKUP为备用服务器

interface eth1  #BACKUP为备用服务器

virtual_router_id 51

priority 100    #定义优先级,数字越大,优先级越高,主DR必须大于备用DR。

advert_int 1

authentication {

auth_type PASS  #设置验证类型,主要有PASS和AH两种

auth_pass 1111  #设置验证密码

}

virtual_ipaddress {

172.16.3.199  #设置主DR的虚拟IP地址(virtual IP),可多设,但必须每行1个

}

}

########Virtual Server########

virtual_server 172.16.3.199 80 {  #注意IP地址与端口号之间用空格隔开

delay_loop 6        #设置健康检查时间,单位是秒

lb_algo rr          #设置负载调度算法,默认为rr,即轮询算法,最优秀是wlc算法

lb_kind DR          #设置LVS实现LB机制,有NAT、TUNN和DR三个模式可选

nat_mask 255.255.255.0

#persistence_timeout 50  #会话保持时间,单位为秒

protocol TCP        #指定转发协议类型,有TCP和UDP两种

real_server 172.16.3.92 80 {

weight 50          #配置节点权值,数字越大权值越高

TCP_CHECK {

connect_timeout 3    #表示3秒无响应,则超时

nb_get_retry 3        #表示重试次数

delay_before_retry 3  #表示重试间隔

}

}

real_server 172.16.3.91 80 {  #配置服务器节点,即Real Server2的public IP

weight 50          #配置节点权值,数字越大权值越高

TCP_CHECK {

connect_timeout 3      #表示3秒无响应,则超时

nb_get_retry 3          #表示重试次数

delay_before_retry 3    #表示重试间隔

}

}

Slave DR的配置和Master DR的配置基本一样,只有2个不同点:
MASTER改为BACKUP,priority 100改为priority 80

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/5793a584e1dc45e4cb48c4579ecefa84.html